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Preface 



Thank you for your interest in the SCC (Serial Communica- 
tion Controller) family of products. 

This manual is intended as a technical resource for part 
numbers Z8030, Z80C30 and Z80230 (Z-Bus) as well as 
Z8530, Z85C30, Z85230, and Z85233 (Universal Bus). If 



you have previously used the Z80 SIO, you will find these 
devices, which share much the same basic architecture, to 
be very familiar. 

The document is organized into nine chapters as follows: 



1. General Description 

Chapter 1 is an introductory section covering the key features and giving an 
overview of block diagrams, pin-outs, pin definitions and signal functions. 

2. Interfacing the SCC/ESCC 

Chapter 2 provides all of the technical information to describe the bus inter 
faces. Included are timing diagrams, register accesses, resets, interrupts, 
Read/Write cycles, programming, DMAs and test functions. 

3. SCC/ESCC Ancillary Support Circuitry 

Chapter 3 covers the SCC's/ESCC's functional details in the areas of baud rate 
generator, data encoding/decoding, digital phased-lock loop (NRZI, FM, 
Manchester modes), transmit clock counter, clock selection and crystal 
oscillator. 

4. Data Communication Modes 

Chapter 4 explains the transmit/receive datapaths, asynchronous modes, byte- 
oriented synchronous modes, and bit-oriented synchronous (SDLC/HDLC) 
modes. 

5. Register Descriptions 

Chapter 5 illustrates and explains all of the bit and byte functions of the 
Read/Write registers. 

6. Z85C30SL1 480 Enhancements 

Chapter 6 explains the SDLC enhancements. 

Application Notes 

This section provides examples and useful tips to aid in development of 
SCC/ESCC Applications. 

Questions and Answers 

This section contains Answers to the most commonly asked SCC/ESCC 
Questions. 

Support Products 

This section contains descriptions of development tools used to support the 
SCC/ESCC. 
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User's Manual 



Chapter 1 

General Description 



1.1 INTRODUCTION 

The Zilog SCC Serial Communication Controller is a dual 
channel, multiprotocol data communication peripheral 
designed for use with 8- and 16-bit microprocessors. The 
SCC functions as a serial-to-parallel, parallel-to-serial con- 
verter/controller. The SCC can be software-configured to 
satisfy a wide variety of serial communications applica- 
tions. The device contains a variety of new, sophisticated 
internal functions including on-chip baud rate generators, 
digital phase-lock loops, and crystal oscillators, which 
dramatically reduce the need for external logic. 

The SCC handles asynchronous formats, synchronous 
byte-oriented protocols such as IBM® Bisync, and syn- 
chronous bit-oriented protocols such as HDLC and IBM 
SDLC. This versatile device supports virtually any serial 
data transfer application (telecommunication, LAN, etc.) 

The device can generate and check CRC codes in any 
synchronous mode and can be programmed to check 
data integrity in various modes. The SCC also has facilities 
for modem control in both channels. In applications where 
these controls are not needed, the modem controls can be 
used for general-purpose I/O. 

With access to 14 Write registers and 7 Read registers per 
channel (the number of the registers varies depending on 
the version), the user can configure the SCC to handle all 
synchronous formats regardless of data size, number of 
stop bits, or parity requirements. 

Within each operating mode, the SCC also allows for 
protocol variations by checking odd or even parity bits, 
character insertion or deletion, CRC generation, checking 
break and abort generation and detection, and many other 
protocol-dependent features. 



The SCC/ESCC family consists of the following seven 
devices; 



NMOS 
CMOS 
ESCC 
EMSCC 



Z-Bus® 
Z8030 
Z80C30 
Z80230 



Universal-Bus 

Z8530 

Z85C30 

Z85230 

Z85233 



As a convention, use the following words to distinguish the 
devices throughout this document. 

SCC: Description applies to all versions. 
NMOS: Description applies to NMOS version 

(Z8030/Z8530) 
CMOS: Description applies to CMOS version 

(Z80C30/Z85C30) 
ESCC: Description applies to ESCC (Z80230/Z85230) 
EMSCC: Description applies to EMSCC (Z85233) 
Z80X30: Description applies to Z-Bus version of the 

device (Z8030/Z80C30/Z80230) 
Z85X3X: Description applies to Universal version of the 
device (Z8530/Z85C30/Z85230/Z85233) 

The Z-Bus version has a multiplexed bus interface and is 
directly compatible with the Z8000, Z16C00 and 80x86 
CPUs. The Universal version has a non-multiplexed bus 
interface and easily interfaces with virtually any CPU, 
including the 8080, Z80, 68X00. The 85C30 (SL1480 
Version) contains added SDLC enhancements which are 
described in Chapter 6. 
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1.2 SCC'S CAPABILITIES 



The NMOS version of the SCC is Zilog's original device. 
The design is based on the Z80 SIO architecture. If you are 
familiar with the Z80 SIO, the SCC can be treated as an SIO 
with support circuitry such as DPLL, BRG, etc. Its features 
include: 

■ Two independent full-duplex channels 

■ Synchronous/lsosynchronous data rates: 

Up to 1/4 of the PCLK using external clock source. 
Up to 5 Mbits/sec at 20 MHz PCLK (ESCC) 
Up to 4 Mbits/sec at 16 MHz PCLK (CMOS) 
Up to 2 MBits/sec at 8 MHz PCLK (NMOS) 

- Up to 1/8 of the PCLK (up to 1/16 on NMOS) 
using FM encoding with DPLL 

- Up to 1/16 of the PCLK (up to 1/32 on NMOS) 
using NRZI encoding with DPLL 

■ Asynchronous Capabilities 

- 5, 6, 7 or 8 bits/character (capable of 
handling 4 bits/character or less.) 

1 , 1 .5, or 2 stop bits 

- Odd or even parity 

- Times 1 , 1 6, 32 or 64 clock modes 
Break generation and detection 

Parity, overrun and framing error detection 

B Byte oriented synchronous capabilities: 

Internal or external character synchronization 

- One or two sync characters (6 or 8 bits/sync 
character) in separate registers 

- Automatic Cyclic Redundancy Check (CRC) 
generation/detection 



SDLC/HDLC capabilities: 

- Abort sequence generation and checking 
Automatic zero insertion and detection 

- Automatic flag insertion between messages 

- Address field recognition 
l-field residue handling 
CRC generation/detection 

- SDLC loop mode with EOP recognition/loop 
entry and exit 



Receiver FIFO 
ESCC* 
NMOS/CMOS: 

Transmitter FIFO 
ESCC: 
NMOS/CMOS: 



8 bytes deep 
3 bytes deep 



4 bytes deep 
1 byte deep 



NRZ, NRZI or FM encoding/decoding. Manchester 
code decoding (encoding with external logic). 

Baud Rate Generator in each channel 

Digital Phase Locked Loop (DPLL) for clock recovery 

Crystal oscillator 
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The CMOS version of the SCC is 1 00% plug compatible to 
the NMOS versions of the device, while providing the 
following additional features: 

■ Status FIFO 

■ Software interrupt acknowledge feature 

■ Enhanced timing specifications 

■ Faster system clock speed 

■ Designed in Zilog's Superintegration™ core format 

■ When the DPLL clock source is external, it can be up 
to 2x the PCLK, where NMOS allows up to PCLK (32.3 
MHz max with 16/20 MHz version). 

ESCC (Enhanced SCC) is pin and software compatible to 
the CMOS version.with the following additional enhance- 
ments. 

■ Deeper transmit FIFO (4 bytes) 

■ Deeper receive FIFO (8 bytes) 

■ Programmable FIFO interrupt and DMA request level 



■ Seven enhancements to improve SDLC link layer 
supports: 

- Automatic transmission of the opening flag 

- Automatic reset of Tx Underrun/EOM latch 
Deactivation of /RTS pin after closing flag 

- Automatic CRC generator preset 

- Complete CRC reception 

- TxD pin automatically forced high with NRZI 
encoding when using mark idle 

- Status FIFO handles better frames with an ABORT 

- Receive FIFO automatically unlocked for special 
receive interrupts when using the SDLC 
status FIFO 

■ Delayed bus latching for easier microprocessor 
interface 

■ New programmable features added with Write Register 
7' (WR seven prime) 

■ Write registers 3, 4, 5 and 10 are now readable 

■ Read register latched during access 

■ DPLL counter output available as jitter-free transmitter 
clock source 

■ Enhanced /DTR, /RTS deactivation timing 
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1.3 BLOCK DIAGRAM 



Figure 1-1 has the block diagram of the SCC. Note that the Detailed internal signal path will be discussed in 
depth of the FIFO differs depending on the version. The Chapter 4. 
10X19 SDLC Frame Status FIFO is not available on the 
NMOS version of the SCC. 



Channel A 

Exploded View 



Databus 



Transmit Logic 



Transmit FIFO 
NM0S/CM0S: 1 byte 
ESCC:4Bytes 



I 



Transmit MUX 



Data Encoding & CRC 
Generation 



Receive and Transmit Clock Multipexer 


Digital 
Phase-Locked 
Loop 


Baud Rate 
Generator 


Crystal 
Oscillator 
Amplifier 



Modem/Control Logic 



Receive Logic 



Rec. Status* 
FIFO 


Rec. Data* 
FIFO 


1 





SDLC Frame Status FIFO 
10x19 



* See Note 



I 



Receive MUX 



CRC Checker, 
Data Decode & 
Sync Character 
Detection 



* NMOS/CMOS: 3 bytes each 
ESCC: 8 bytes 

** Not Available on NMOS 
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Figure 1-1. SCC Block Diagram 



1-4 



1.4 PIN DESCRIPTIONS 



The SCC pins are divided into seven functional groups: 
Address/Data, Bus Timing and Reset, Device Control, 
Interrupt, Serial Data (both channels), Peripheral Control 
(both channels), and Clocks (both channels). Figures 1-2 
and 1-3 show the pins in each functional group for both 
Z80X30 and Z85X30. Notice the pin functions unique to 
each bus interface version in the Address/Data group, Bus 
Timing and Reset group, and Control groups. 

The Address/Data group consists of the bi-directional 
lines used to transfer data between the CPU and the SCC 
(Addresses in the Z80X30 are latched by /AS). The direc- 
tion of these lines depends on whether the operation is a 
Read or Write. 



The timing and control groups designate the type of 
transaction to occur and when it will occur. The interrupt 
group provides inputs and outputs to conform to the 
Z-Bus® specifications for handling and prioritizing inter- 
rupts. The remaining groups are divided into channel A 
and channel B groups for serial data (transmit or receive), 
peripheral control (such as DMA or modem), and the input 
and output lines for the receive and transmit clocks. 

The signal functionality and pin assignments (Figures 1-4 
to 1-7) stay constant within the same bus interface group 
(i.e Z80X30, Z85X30), except for some timing and/or DC 
specification differences. For details, please reference the 
individual product specifications. 
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Figure 1-3. Z80X30 Pin Functions 
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Figure 1-5. Z85X30 PLCC Pin Assignments 



Figure 1-4. Z85X30 DIP Pin Assignments 
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Figure 1-7. Z80X30 PLCC Pin Assignments 



Figure 1-6. Z80X30 DIP Pin Assignments 



1 .4.1 Pins Common to both Z85X30 
and Z80X30 

/CTSA, /CTSB. Clear To Send (inputs, active Low). These 
pins function as transmitter enables if they are programmed 
for Auto Enable (WR3, D5= 1 J. A Low on the inputs enables 
the respective transmitters. If not programmed as Auto 
Enable, they may be used as general-purpose inputs. Both 
inputs are Schmitt-trigger buffered to accommodate slow 
rise-time inputs. The SCC detects pulses on these inputs 
and can interrupt the CPU on both logic level transitions. 

/DCDA, /DCDB. Data Carrier Detect (inputs, active Low). 
These pins function as receiver enables if they are pro- 
grammed for Auto Enable (WR3, D5=1); otherwise, they 
are used as general-purpose input pins. Both pins are 
Schmitt-trigger buffered to accommodate slow rise time 
signals. The SCC detects pulses on these pins and can 
interrupt the CPU on both logic level transitions. 

/RTSA, /RTSB. Request To Send (outputs, active Low). 
The /RTS pins can be used as general purpose outputs or 
with the Auto Enable feature. When used with Auto Enable 
ON (WR3, D5=1) in asynchronous mode, the /RTS pin 



goes High after the transmitter is empty. When Auto Enable 
is OFF, the /RTS pins are used as general purpose outputs, 
and, they strictly follow the inverse state of WR5, bit D1 . 

ESCC: 

In SDLC mode, the /RTS pins can be programmed to be 
deasserted when the closing flag of the message clears 
the TxD pin, if WR7' D2 is set 

/SYNCA, /SYNCB. Synchronization (inputs or outputs, 
active Low). These pins can act either as inputs, outputs, 
or part of the crystal oscillator circuit. In the Asynchronous 
Receive mode (crystal oscillator option not selected), 
these pins are inputs similar to CTS and DCD. In this mode, 
transitions on these lines affect the state of the Synchronous/ 
Hunt status bits in Read Register but have no other 
function. 

In External Synchronization mode, with the crystal oscilla- 
tor not selected, these lines also act as inputs. In this mode, 
/SYNC is driven Low to receive clock cycles after the last 
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bit in the synchronous character is received. Character 
assembly begins on the rising edge of the receive clock 
immediately preceding the activation of SYNC. 

In the Internal Synchronization mode (Monosync and 
Bisync) with the crystal oscillator not selected, these pins 
act as outputs and are active only during the part of the 
receive clock cycle in which the synchronous condition is 
not latched. These outputs are active each time a syn- 
chronization pattern is recognized (regardless of character 
boundaries). In SDLC mode, the pins act as outputs and 
are valid on receipt of a flag. The /SYNC pins switch from 
input to output when monosync, bisync, or SDLC is pro- 
grammed in WR4 and sync modes are enabled. 

/DTR//REQA, /DTR//REQB. Data Terminal Ready/Request 
(outputs, active Low). These pins are programmable (WR1 4, 
D2) to serve either as general purpose outputs or as DMA 
Request lines. When programmed for DTR function (WR1 4 
D2=0), these outputs follow the state programmed into the 
DTR bit of Write Register 5 (WR5 D7). When programmed 
for Ready mode, these pins serve as DMA Requests for the 
transmitter. 

ESCC: 

When used as DMA request lines (WR14, D2=1), the 
timing for the deactivation request can be programmed in 
the added register, Write Register 7' (WR7 1 ) bit D4. If this 
bit is set, the/DTR/IREQ pin is deactivated with the same 
timing as the/W/REQ pin. If WR7' D4 is reset, the deacti- 
vation timing of /DTR//REQ pin is four clock cycles, the 
same as in the Z85C30. 

/W//REQA, /W//REQB. Wait/Request (outputs, open-drain 
when programmed for Wait function, driven High or Low 
when programmed for Ready function). These dual-pur- 
pose outputs may be programmed as Request lines for a 
DMA controller or as Wait lines to synchronize the CPU to 
the SCC data rate. The reset state is Wait. 

RxDA, RxDB. Receive Data (inputs, active High). These 
input signals receive serial data at standard TTL levels. 

/RTxCA,/RTxCB. Receive/Transmit Clocks (inputs, active 
Low). These pins can be programmed to several modes of 
operation. In each channel, /RTxC may supply the receive 
clock, the transmit clock, the clock for the baud rate 
generator, or the clock for the Digital Phase-Locked Loop. 
These pins can also be programmed for use with the 
respective SYNC pins as a crystal oscillator. The receive 
clock may be 1, 16, 32, or 64 times the data rate in 
asynchronous modes. 

TxDA, TxDB. Transmit Data (outputs, active High). These 
output signals transmit serial data at standard TTL levels. 



/TRxCA, /TRxCB. Transmit/Receive Clocks (inputs or 
outputs, active Low). These pins can be programmed in 
several different modes of operation. /TRxC may supply 
the receive clock or the transmit clock in the input mode or 
supply the output of the Transmit Clock Counter (which 
parallels the Digital Phase-Locked Loop), the crystal os- 
cillator, the baud rate generator, or the transmit clock in the 
output mode. 

PCLK. Clock (input). This is the master SCC clock used to 
synchronize internal signals. PCLK is a TTL level signal. 
PCLK is not required to have any phase relationship with 
the master system clock. 

IEI. Interrupt Enable In (input, active High). IEI is used with 
IEO to form an interrupt daisy chain when there is more 
than one interrupt driven device. A high IEI indicates that 
no other higher priority device has an interrupt under 
service or is requesting an interrupt. 

IEO. Interrupt Enable Oitf (output, active High). IEO is High 
only if IEI is High and the CPU is not servicing the SCC 
interrupt or the SCC is not requesting an interrupt (Interrupt 
Acknowledge cycle only). IEO is connected to the next 
lower priority device's IEI input and thus inhibits interrupts 
from lower priority devices. 

/INT. lnterrupt(output, open drain, active Low). This signal 
is activated when the SCC requests an interrupt. Note that 
/INT is an open-drain output. 

/INTACK. Interrupt Acknowledge (input, active Low). This 
is a strobe which indicates that an interrupt acknowledge 
cycle is in progress. During this cycle, the SCC interrupt 
daisy chain is resolved. The device is capable of returning 
an interrupt vector that may be encoded with the type of 
interrupt pending. During the acknowledge cycle, if IEI is 
high, the SCC places the interrupt vector on the databus 
when /RD goes active. /INTACK is latched by the rising 
edge of PCLK. 

1 .4.2 Pin Descriptions, (Z85X30 Only) 

D7-D0. Data bus (bidirectional, 3-state). These lines carry 
data and commands to and from the Z85X30. 

/CE. Chip Enable (input, active Low). This signal selects 
the Z85X30 for a read or write operation. 

/RD. Read (input, active Low). This signal indicates a read 
operation and when the Z85X30 is selected, enables the 
Z85X30's bus drivers. During the Interrupt Acknowledge 
cycle, /RD gates the interrupt vector onto the bus if the 
Z85X30 is the highest priority device requesting an inter- 
rupt. 
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/WR. Write (input, active Low). When the Z85X30 is se- 
lected, this signal indicates a write operation. This indi- 
cates that the CPU wants to write command bytes or data 
to the Z85X30 write registers. 

A//B. Channel A/Channel B (input). This signal selects the 
channel in which the read or write operation occurs. High 
selects channel A and Low selects channel B. 

D//C. Data/Control Select (input). This signal defines the 
type of information transferred to or from the Z85X30. High 
means data is being transferred and Low indicates a 
command. 

1 .4.3 Pin Descriptions, (Z80X30 Only) 

AD7-AD0. Address/Data Bus (bidirectional, active High, 
3-state). These multiplexed lines carry register addresses 
to the Z80X30 as well as data or control information to and 
from the Z80X30. 



R//W. Read//Write (input, read active High). This signal 
specifies whether the operation to be performed is a read 
or a write. 

/CSO. Chip Select (input, active Low). This signal is 
latched concurrently with the addresses on AD7-AD0 and 
must be active for the intended bus transaction to occur. 

CS1 . Chip Select 1 (input, active High). This second select 
signal must also be active before the intended bus trans- 
action can occur. CS1 must remain active throughout the 
transaction. 

/DS. Data Strobe (input, active Low). This signal provides 
timing for the transfer of data into and out of the Z80X30. 
If /AS and /DS are both Low, this is interpreted as a reset. 

/AS. Address Strobe (input, active Low). Address on ADZ- 
ADO are latched by the rising edge of this signal. 



1-9 



<£>ZiLOE 



USER'S MANUAL 



2.1 INTRODUCTION 

This chapter covers the system interface requirements 
with the SCC. Timing requirements for both devices are 
described in a general sense here, and the user should 
refer to the SCC Product Specification for detailed AC/DC 
parametric requirements. 

The ESCC has an additional new register, Write Register 
Seven Prime (WR7'). Its features include the ability to read 
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INTERFACING THE SCC/ESCC 



WR3, WR4, WR5, WR7\ and WR10. Both the Z80230 and 
the Z85230 have the ability to deassert the /DTR//REQ pin 
quickly to ease DMA interface design. Additionally, the 
Z85230 features a relaxed requirement for a valid data bus 
when the /WR pin goes Low. The effects of the deeper data 
FIFOs should be considered when writing the interrupt 
service routines. The user should read the sections which 
follow for details on these features. 



2.2 Z80X30 INTERFACE TIMING 

The Z-Bus® compatible SCC is suited for system applica- 
tions with multiplexed address/data buses similar to the 
Z8®, Z8000®, and Z280®. 

Two control signals, /AS and /DS, are used by the Z80X30 
to time bus transactions. In addition, four other control 
signals (/CSO, CS1, R//W, and /INTACK) are used to 
control the type of bus transaction that occurs. A bus 
transaction is initiated by /AS; the rising edge latches the 
register address on the Address/Data bus and the state of 
/INTACK and /CSO. 

In addition to timing bus transactions, /AS is used by the 
interrupt section to set the Interrupt Pending (IP) bits. 
Because of this, /AS must be kept cycling for the interrupt 
section to function properly. 



The Z80X30 generates internal control signals in response 
to a register access. Since /AS and /DS have no phase 
relationship with PCLK, the circuit generating these inter- 
nal control signals provides time for metastable conditions 
to disappear. This results in a recovery time related to 
PCLK. 

This recovery time applies only to transactions involving 
the Z80X30, and any intervening transactions are ignored. 
This recovery time is four PCLK cycles, measured from the 
falling edge of /DS of one access to the SCC, to the falling 
edge of /DS for a subsequent access. 
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2.2.1 Z80X30 Read Cycle Timing 



The read cycle timing for the Z80X30 is shown in edge of /AS. R//W must be High before IDS falls to indicate 
Figure 2-1. The register address on AD7-AD0, as well as a read cycle. The Z80X30 data bus drivers are enabled 
the state of /CSO and /INTACK, are latched by the rising while CS1 is High and IDS is Low. 
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Figure 2-1. Z80X30 Read Cycle 
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2.2.2 Z80X30 Write Cycle Timing 



The write cycle timing for the Z80X30 is shown in 
Figure 2-2. The register address on AD7-AD0, as well as 
the state of /CSO and /INTACK, are latched by the rising 
edge of /AS. R//W must be Low when IDS falls to indicate 



a write cycle. The leading edge of the coincidence of CS1 
High and /DS Low latches the write data on AD7-AD0, as 
well as the state of R//W. 
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Figure 2-2. Z80X30 Write Cycle 



2-3 



2.2.3 Z80X30 Interrupt Acknowledge Cycle Timing 



The interrupt acknowledge cycle timing for the Z80X30 is 
shown in Figure 2-3. The address on AD7-AD0 and the 
state of /CSO and /INTACK are latched by the rising edge 



of /AS. However, if /INTACK is Low, the address, /CSO, CS1 
and R//W are ignored for the duration of the interrupt 
acknowledge cycle. 
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IEI 
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Figure 2-3. Z80X30 Interrupt Acknowledge Cycle 



The Z80X30 samples the state of /INTACK on the rising 
edge of /AS, and AC parameters #7 and #8 specify the 
setup and hold-time requirements. Between the rising 
edge of /AS and the falling edge of /DS, the internal and 
external daisy chains settle (AC parameter #29). A system 
with no external daisy chain should provide the time 
specified in spec #29 to settle the interrupt daisy-chain 



priority internal to the SCC. Systems using an external 
daisy chain should refer to Note 5 referenced in the 
Z80X30 Read/Write & Interrupt Acknowledge Timing for 
the time required to settle the daisy chain. 

Note: /INTACK is sampled on the rising edge of /AS. If it 
does not meet the setup time to the first rising edge of /AS 
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of the interrupt acknowledge cycle, it is latched on the next 
rising edge of /AS. Therefore, if /INTACK is asynchronous 
to /AS, it may be necessary to add a PCLK cycle to the 
calculation for /INTACK to /RD delay time. 

If there is an interrupt pending in the SCC, and IEI is High 
when /DS falls, the acknowledge cycle was intended for 
the SCC. This being the case, the Z80X30 sets the Inter- 
rupt-Under-Service (IUS) latch for the highest priority pend- 
ing interrupt, as well as placing an interrupt vector on ADZ- 
ADO. The placing of a vector on the bus can be disabled 
by setting WR9, D1=1. The /INT pin also goes inactive in 
response to the falling edge of /DS. Note that there should 
be only one /DS per acknowledge cycle. Another impor- 
tant fact is that the IP bits in the Z80X30 are updated by /AS, 
which may delay interrupt requests if the processor does 
not supply /AS strobes during the time between accesses 
of the Z80X30. 

2.2.4 Z80X30 Register Access 

The registers in the Z80X30 are addressed via the address 
on AD7-AD0 and are latched by the rising edge of /AS. The 
Shift Right/Shift Left bit in the Channel B WRO controls 
which bits are decoded to form the register address. It is 
placed in this register to simplify programming when the 
current state of the Shift Right/Shift Left bit is not known. 



A hardware reset forces Shift Left mode where the address 
is decoded from AD5-AD1 . In Shift Right mode, the address 
is decoded from AD4-AD0. The Shift Right/Shift Left bit is 
written via a command to make the software writing to WRO 
independent of the state of the Shift Right/Shift Left bit. 

While in the Shift Left mode, the register address is placed 
on AD4-AD1 and the Channel Select bit, A/B, is decoded 
from AD5. The register map for this case is shown in 
Table 2-1 . In Shift Rightmode, the register address is again 
placed on AD4-AD1 but the channel select A/B is decoded 
from ADO. The register map for this case is shown in 
Table 2-2. 

Because the Z80X30 does not contain 16 read registers, 
the decoding of the read registers is not complete; this is 
indicated in Table 2-1 and Table 2-2 by parentheses 
around the register name. These addresses may also be 
used to access the read registers. Also, note that the 
Z80X30 contains only one WR2 and WR9; these registers 
may be written from either channel. 

Shift Left Mode is used when Channel A and B are to be 
programmed differently. This allows the software to se- 
quence through the registers of one channel at a time. The 
Shift Right Mode is used when the channels are pro- 
grammed the same. By incrementing the address, the user 
can program the same data value into both the Channel A 
and Channel B register. 
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Table 2-1. Z80X30 Register Map (Shift Left Mode) 
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Notes: 

The register names in ( ) are the values read outfrom that register location. 
WR15, bit D2 enables status FIFO function (not available on NMOS). 
WR7' bit D6 enables extend read function (only on ESCC). 
* Includes 80C30/230 when WR1 5 D2=0. 
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Table 2-2. Z80X30 Register Map (Shift Right Mode) 
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RR10B 


RR10B 


RR10B 


1 





1 





1 


WR10A 


RR10A 


RR10A 


RR10A 


1 





1 


1 





WR11B 


(RR15B) 


(RR15B) 


(WR10B) 




u 


A 
I 


A 

I 


A 

\ 


\A/DH H A 

Wnl I A 


/DDH CAN 


/DDH KAN 

(nnl OA; 


MA/DH HAN 

(WnlUAj 


1 


1 











WR12B 


RR12B 


RR12B 


RR12B 


1 


1 








1 


WR12A 


RR12A 


RR12A 


RR12A 


1 


1 





1 





WR13B 


RR13B 


RR13B 


RR13B 









1 


1 


WR13A 


RR13A 


RR13A 


RR13A 






1 








WR14B 


RR14B 


RR14B 


(WR7'B) 






1 





1 


WR14A 


RR14A 


RR14A 


(WR7'A) 






1 


1 





WR15B 


RR15B 


RR15B 


RR15B 






1 


1 


1 


WR15A 


RR15A 


RR15A 


RR15A 



Notes: 

The register names in () are the values read out from that register location. 
WR15 bit D2 enables status FIFO function (not available on NMOS). 
WR7' bit D6 enables extend read function (only on ESCC). 
* Includes 80C30/230 when WR1 5 D2=0. 
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2.2.5 Z80C30 Register Enhancement 



The Z80C30 has an enhancement to the NMOS Z8030 
register set, which is the addition of a 10x19 SDLC Frame 
Status FIFO. When WR15 bit D2= 1 , the SDLC Frame Status 
FIFO is enabled, and it changes the functionality of RR6 
and RR7. See Section 4.4.3 for more details on this feature. 

2.2.6 Z80230 Register Enhancements 

In addition to the Z80C30 enhancements, the 80230 has 
several enhancements to the SCC register set. These 
include the addition of Write Register 7 Prime (WR7'), and 
the ability to read registers that are read only in the 8030. 

Write Register 7' is addressed by setting WR15 bit, D0=1 
and then addressing WR7. Figure 2-4 shows the register 
bit location of the six features enabled through this regis- 
ter. All writes to address seven are to WR7' when WR15, 
D0=1 . Refer to Chapter 5 for detailed information on WR7'. 



WRr 

D7 I D6 I D5 I D4 I D3 I D2 I D1 I DO 



WR7' bit D6=1 , enables the extended read register capa- 
bility. This allows the user to read the contents of WR3, 
WR4, WR5, WR7' and WR10 by reading RR9, RR4, RR5, 
RR14 and RR11, respectively. When WR7' D6=0, these 
write registers are write only. 

Table 2-3 shows what functions are enabled for the various 
combinations of register bit enables. See Table 2-1 (Shift 
Left) and Table 2-2 (Shift Right) for the register address 
map with the SDLC FIFO enabled only and the map with 
both the extended read and SDLC FIFO features enabled. 



Table 2-3. Z80230 SDLC/HDLC Enhancement Op- 
tions 



WR15 


WR7' 




BitD2 Bit DO 


Bit D6 


Functions Enabled 


1 





WR7' enabled only 


1 


1 


WR7' with extended read 






enabled 


1 


X 


10x19 SDLC FIFO 






enhancement 






enabled only 


1 1 





10x19 SDLC FIFO and WR7' 


1 1 


1 


10x19 SDLC FIFO and WR7' 






with extended read enabled 



Auto Tx Flag 
Auto EOM Reset 
Auto RTS Turnoff 
Rx FIFO Half Full 
DTR/REQ Timing Mode 
Tx FIFO Empty 
External Read Enable 




Figure 2-4. Write Register 7 Prime (WR7 1 ) 
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2.2.7 Z80X30 Reset 



The Z80X30 may be reset by either a hardware or software 
reset. Hardware reset occurs when /AS and /DS are both 
Low at the same time, which is normally an illegal condi- 
tion. As long as both /AS and /DS are Low, the Z80X30 
recognizes the reset condition. However, once this condi- 
tion is removed, the reset condition is asserted internally 
for an additional four to five PCLK cycles. During this time, 
any attempt to access is ignored. 

The Z80X30 has three software resets that are encoded 
into two command bits in WR9. There are two channel 



resets, which only affect one channel in the device and 
some bits of the write registers. The command forces the 
same result as the hardware reset, the Z80X30 stretches 
the reset signal an additional four to five PCLK cycles 
beyond the ordinary valid access recovery time. The bits 
in WR9 may be written at the same time as the reset 
command because these bits are affected only by a 
hardware reset. The reset values of the various registers 
are shown in Table 2-4. 



Table 2-4. Z80X30 Register Reset Values 



Hardware RESET Channel RESET 





7 

1 


c 
D 


c 
o 








1 


u 


■7 


D 


o 


A 

4 


Q 

o 


o 
c. 


1 

1 


u 


WRO 


o 


o 


o 


o 


o 


o 


o 


o 


o 


o 


o 














o 


WR1 








X 








X 














X 








X 








WR2 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR3 


X 


X 


X 


X 


X 


X 


X 





X 


X 


X 


X 


X 


X 


X 





WR4 


X 


X 


X 


X 


X 


1 


X 


X 


X 


X 


X 


X 


X 


1 


X 


X 


WR5 





X 


X 














X 





X 


X 














X 


WR6 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR7 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR7'* 








1 























1 

















WR9 


1 


1 














X 


X 


X 


X 





X 


X 


X 


X 


X 


WR10 





























X 


X 

















WR11 














1 











X 


X 


X 


X 


X 


X 


X 


X 


WR12 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR13 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR14 


X 


X 


1 


1 














X 


X 


1 











X 


X 


WR15 


1 


1 


1 


1 


1 











1 


1 


1 


1 


1 











RRO 


X 


1 


X 


X 


X 


1 








X 


1 


X 


X 


X 


1 








RR1 

















1 


1 


X 

















1 


1 


X 


RR3 


















































RR10 





X 























X 





















Notes: 

*WR7' is available only on the Z80230. 
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2.3 Z85X30 INTERFACE TIMING 



Two control signals, /RD and /WR, are used by the Z85X30 
to time bus transactions. In addition, four other control 
signals, /CE, D//C, A//B and /INTACK, are used to control 
the type of bus transaction that occurs. A bus transaction 
starts when the addresses on D//C and A//B are asserted 
before /RD or /WR fall (AC Spec #6 and #8). The coinci- 
dence of /CE and /RD or /CE and /WR latches the state of 
D//C and A//B and starts the internal operation. The 
/INTACK signal must have been previously sampled High 
by a rising edge of PCLK for a read or write cycle to occur. 
In addition to sampling /INTACK, PCLK is used by the 
interrupt section to set the IP bits. 

The Z85X30 generates internal control signals in response 
to a register access. Since /RD and /WR have no phase 
relationship with PCLK, the circuitry generating these 
internal control signals provides time for metastable con- 
ditions to disappear. This results in a recovery time related 
to PCLK. 



This recovery time applies only between transactions 
involving the Z85X30, and any intervening transactions are 
ignored. This recovery time is four PCLK cycles (AC Spec 
#49), measured from the falling edge of /RD or /WR in the 
case of a read or write of any register. 

2.3.1 Z85X30 Read Cycle Timing 

The read cycle timing for the Z85X30 is shown in 
Figure 2-5. The address on A//B and D//C is latched by the 
coincidence of /RD and /CE active. /CE must remain Low 
and /INTACK must remain High throughout the cycle. The 
Z85X30 bus drivers are enabled while /CE and /RD are 
both Low. A read with D//C High does not disturb the state 
of the pointers and a read cycle with D//C Low resets the 
pointers to zero after the internal operation is complete. 



A//B, D//C 



x 



Address Valid 



X 



/INTACK 



/CE 



Z 



/RD 



\ 



D7-D0 



Figure 2-5. Z85X30 Read Cycle Timing 
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2.3.2 Z85X30 Write Cycle Timing 



The write cycle timing for the Z85X30 is shown in 
Figure 2-6. The address on A//B and D//C, as well as the 
data on D7-D0, is latched by the coincidence of /WR and 
/CE active. /CE must remain Low and /INTACK must 
remain High throughout the cycle. A write cycle with D//C 
High does not disturb the state of the pointers and a write 
cycle with D//C Low resets the pointers to zero after the 
internal operation is complete. 



Historically, the NMOS/CMOS version latched the data 
bus on the falling edge of /WR. However, many CPUs do 
not guarantee that the data bus is valid at the time when the 
/WR pin goes low, so the data bus timing was modified to 
allow a maximum delay from the falling edge of /WR to the 
latching of the data bus. On the Z85230, the AC Timing 
parameter #29 TsDW(WR), Write Data to /WR falling mini- 
mum, has been changed to: /WR falling to Write Data Valid 
maximum. Refer to the AC Timing Characteristic section of 
the Z85230 Product Specification for more information 
regarding this change. 



NIB, D//C 



x 



Address Valid 



X 



/INTACK 



/CE 



X 



z 



/WR 



\ See Note 
N. 



D7-D0 



Note: Dotted line is ESCC only. 



< 



Data Valid 



> 



Figure 2-6. Z85X30 Write Cycle Timing 



2.3.3 Z85X30 Interrupt Acknowledge Cycle Timing 

The interrupt acknowledge cycle timing for the Z85X30 is rising edge of PCLK (AC Spec #1 0). While /INTACK is Low, 
shown in Figure 2-7. The state of /INTACK is latched by the the state of A//B, /CE, D//C, and /WR are ignored. 



/INTACK 



/RD 



ss- 
s- 



\ 



s 



D7-D0 



< x «~ y 



Figure 2-7. Z85X30 Interrupt Acknowledge Cycle Timing 
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Between the time /INTACK is first sampled Low and the 
time /RD falls, the internal and external IEI/IEO daisy chain 
settles (AC parameter #38 TdlAI(RD) Note 5). A system 
with no external daisy chain must provide the time speci- 
fied in AC Spec #38 to settle the interrupt daisy chain 
priority internal to the SCC. Systems using the external 
IEI/IEO daisy chain should refer to Note 5 referenced in the 
Z85X30 Read/Write and Interrupt Acknowledge Timing for 
the time required to settle the daisy chain. 

Note: /INTACK is sampled on the rising edge of PCLK. If it 
does not meet the setup time to the first rising edge of 
PCLK of the interrupt acknowledge cycle, it is latched on 
the next rising edge of PCLK. Therefore, if 
/INTACK is asynchronous to PCLK, it may be necessary to 
add a PCLK cycle to the calculation for /INTACK to /RD 
delay time. 

If there is an interrupt pending in the Z85X30, and IEI is 
High when /RD falls, the interrupt acknowledge cycle was 
intended for the Z85X30. In this case, the Z85X30 sets the 
appropriate Interrupt-Under-Service latch, and places an 
interrupt vector on D7-D0. 

If the falling edge of /RD sets an IUS bit in the Z85X30, the 
/INT pin goes inactive in response to the falling edge. Note 
that there should be only one /RD per acknowledge cycle. 

Note 1 : The IP bits in the Z85X30 are updated by PCLK. 
However, when the register pointer is pointing to RR2 and 
RR3, the IP bits are prevented from changing. This pre- 
vents data changing during a read, but will delay interrupt 
requests if the pointers are left pointing at these registers. 

Note 2: The SCC should only receive one INTACK signal 
per acknowledge cycle. Therefore, if the CPU generates 
more than one (as is common for the 80X86 family), an 
external circuit should be used to convert this into a single 
pulse or does not use Interrupt Acknowledge. 



2.3.4 Z85X30 Register Access 

The registers in the Z85X30 are accessed in a two step 
process, using a Register Pointer to perform the address- 
ing. To access a particular register.the pointer bits are set 
by writing to WRO. The pointer bits may be written in either 
channel because only one set exists in the Z85X30. After 
the pointer bits are set, the next read or write cycle of the 
Z85X30 having D//C Low will access the desired register. 
At the conclusion of this read or write cycle the pointer bits 
are reset to 0s, so that the next control write is to the 
pointers in WRO. 

A read to RR8 (the receive data Fl FO) or a write to WR8 (the 
transmit data FIFO) is either done in this fashion or by 
accessing the Z85X30 having D//C pin High. A read or 
write with D//C High accesses the data registers directly, 
and independently of the state of the pointer bits. This 
allows single-cycle access to the data registers and does 
not disturb the pointer bits. 

The fact that the pointer bits are reset to 0, unless explicitly 
set otherwise, means that WRO and RRO may also be 
accessed in a single cycle. That is, it is not necessary to 
write the pointer bits with before accessing WRO or RRO. 

There are three pointer bits in WRO, and these allow access 
to the registers with addresses 7 through 0. Note that a 
command may be written to WRO at the same time that the 
pointer bits are written. To access the registers with ad- 
dresses 15 through 8, the Point High command must 
accompany the pointer bits. This precludes concurrently 
issuing a command when pointing to these registers. 

The register map for the Z85X30 is shown in Table 2-5. If, 
for some reason, the state of the pointer bits is unknown 
they may be reset to by performing a read cycle with the 
D//C pin held Low. Once the pointer bits have been set, the 
desired channel is selected by the state of the A//B pin 
during the actual read or write of the desired register. 
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Table 2-5. Z85X30 Register Map 













READ 8530 




85230 












85C30/230 


85C30/230 


WR15D2=1 


A/R 
n/D 


i IN 1 C. 


PMT1 
r IN I I 


r IN 1 U 


WRITE 

vvm i c 


\a/ri ^ no — n 
vvn i o xjc. — u 


wpir no— 1 
vvn io u^— i 


WR7 1 nR— 1 
vvn/ uo-i 














WROB 


RROB 


RROB 


RROB 











1 


WR1B 


RR1B 


RR1B 


RR1B 








1 





WR2 


RR2B 


RR2B 


RR2B 


U 


U 


A 

I 


I 


WnoD 


nnon 

nriob 


nno □ 

nnoD 


DDOD 

nnob 





1 








WR4B 


(RROB) 


(RROB) 


(WR4B) 





1 





1 


WR5B 


(RR1B) 


(RR1B) 


(WR5B) 





1 


1 





WR6B 


(RR2B) 


RR6B 


RR6B 


U 


H 
I 


I 


H 

\ 


VA/D7D 


/DDQDN 

(nndb) 


DD7D 

Hn/b 


□D7D 

nn/D 














WROA 


RROA 


RROA 


RROA 











1 


WR1A 


RR1A 


RR1A 


RR1A 








1 





WR2 


RR2A 


RR2A 


RR2A 


U 


U 


-4 

I 


1 


WR3A 


nno a 

RR3A 


nno A 

nno A 


nno A 

nno A 





1 








WR4A 


(RROA) 


(RROA) 


(WR4A) 





1 





1 


WR5A 


(RR1A) 


(RR1A) 


(WR5A) 





1 


1 





WR6A 


(RR2A) 


RR6A 


RR6A 





1 


1 


1 


WR7A 


(RR3A) 


RR7A 


RR7A 


With Point High Command 























WR8B 


RR8B 


RR8B 


RR8B 










1 


WR9 


(RR13B) 


(RR13B) 


(WR3B) 







1 





WR10B 


RR10B 


RR10B 


RR10B 







1 


1 


\A/DH H D 

Wnl 1 D 


/nn-| pq\ 

(nnlODj 


/DDI CD\ 






1 








WR12B 


RR12B 


RR12B 


RR12B 




1 





1 


WR13B 


RR13B 


RR13B 


RR13B 




1 


1 





WR14B 


RR14B 


RR14B 


(WR7'B) 




1 


1 


H 

1 


\A/D-1 CD 


DDI CO 

nnlOD 


DDI CD 

nmOD 


□ DH CD 

nnlOD 













WR8A 


RR8A 


RR8A 


RR8A 










1 


WR9 


(RR13A) 


(RR13A) 


(WR3A) 







1 





WR10A 


RR10A 


RR10A 


RR10A 







1 


1 


WR11A 


(RR15A) 


(RR15A) 


(WR10A) 




1 








WR12A 


RR12A 


RR12A 


RR12A 




1 





1 


WR13A 


RR13A 


RR13A 


RR13A 




1 


1 





WR14A 


RR14A 


RR14A 


(WR7'A) 




1 


1 


1 


WR15A 


RR15A 


RR15A 


RR15A 



Notes: 

WR15 bit D2 enables status FIFO function. (Not available on NMOS) 
WR7' bit D6 enables extend read function. (Only on ESCC) 



2-13 



2.3.5 Z85C30 Register Enhancement 



The Z85C30 has an enhancement to the NMOS Z8530 
register set, which is the addition of a 1 x 1 9 SDLC Frame 
Status FIFO. When WR15 bit D2= 1 , the SDLC Frame Status 
FIFO is enabled, and it changes the functionality of RR6 
and RR7. See Section 4.4.3 for more details on this feature. 

2.3.6 Z85230 Register Enhancements 

In addition to the 85C30 enhancements, the 85230 pro- 
vides several enhancements to the SCC register set. 
These include the addition of Write Register 7 Prime 
(WR7 1 ), the ability to read registers that are write-only in 
the SCC. 

Write Register 7' is addressed by setting WR1 5, D0=1 and 
then addressing WR7. Figure 2-8 shows the register bit 
location of the six features enabled through this register. 
All writes to address seven are to WR7' when WR15 D0=1 . 
Refer to Chapter 5 for detailed information on WR7'. 

WR7' 

I D7| D6| D5| D4| D3 1 D2| D1 1 Dol 



1 Auto Tx Flag 

I Auto EOM Reset 

' Auto RTS Turnoff 

■ Rx FIFO Half Full 

' DTR/REQ Timing Mode 

I Tx FIFO Empty 

— — — — — — — Extended Read Enable 

— 

Figure 2-8. Write Register 7 Prime (WR7 1 ) 



Setting WR7' bit D6=1 enables the extended read register 
capability. This allows the user to read the contents of 
WR3, WR4. WR5, WR7' and WR10 by reading RR9. RR4, 
RR5, RR14 and RR11, respectively. When WR7 1 D6=0, 
these write registers are write-only. 

Table 2-6 shows what functions are enabled for the various 
combinations of register bit enables. See Table 2-5 for the 
register address map with only the SDLC FIFO enabled 
and with both the extended read and SDLC FIFO features 
enabled. 



Table 2-6. Z85230 Register Enhancement Options 



WR15 


WR7' 




BitD2 Bit DO 


Bit D6 


Functions Enabled 


1 





WR7' enabled only 


1 


1 


WR7' with extended read 






enabled 


1 


X 


10x19 SDLC FIFO 






enhancement enabled only 


1 1 





10x19 SDLC FIFO and WR7 1 


1 1 


1 


10x19 SDLC FIFO and WR7' 






with extended read enabled 



2.3.7 Z85X30 Reset 

The Z85X30 may be reset by either a hardware or software 
reset. Hardware reset occurs when /WR and /RD are both 
Low at the same time, which is normally an illegal condi- 
tion. As long as both /WR and /RD are Low, the Z85X30 
recognizes the reset condition. However, once this condi- 
tion is removed, the reset condition is asserted internally 
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for an additional four to five PCLK cycles. During this time 
any attempt to access is ignored. 

The Z85X30 has three software resets that are encoded 
into the command bits in WR9. There are two channel 
resets which only affect one channel in the device and 
some bits of the write registers. The command forces the 



same result as the hardware reset, the Z85X30 stretches 
the reset signal an additional four to five PCLK cycles 
beyond the ordinary valid access recovery time. The bits 
in WR9 may be written at the same time as the reset 
command because these bits are affected only by a 
hardware reset. The reset values of the various registers 
are shown in Table 2-7. 



Table 2-7. Z85X30 Register Reset Values 



Hardware RESET Channel RESET 





7 


6 


5 


4 


3 


2 


1 





7 


6 


5 


4 


3 


2 


1 





WRO 


















































WR1 








X 








X 














X 








X 








WR2 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR3 


X 


X 


X 


X 


X 


X 


X 





X 


X 


X 


X 


X 


X 


X 





WR4 


X 


X 


X 


X 


X 


1 


X 


X 


X 


X 


X 


X 


X 


1 


X 


X 


WR5 





X 


X 














X 





X 


X 














X 


WR6 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR7 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR7'* 








1 























1 

















WR9 


1 


1 














X 


X 


X 


X 





X 


X 


X 


X 


X 


WR10 





























X 


X 

















WR11 














1 











X 


X 


X 


X 


X 


X 


X 


X 


WR12 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR13 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


WR14 


X 


X 


1 


1 














X 


X 


1 











X 


X 


WR15 


1 


1 


1 


1 


1 











1 


1 


1 


1 


1 











RRO 


X 


1 


X 


X 


X 


1 








X 


1 


X 


X 


X 


1 








RR1 

















1 


1 


X 

















1 


1 


X 


RR3 


















































RR10 


0/ 


X 























X 





















Notes: 

* WR7' is only available on the ESCC. 



2.4 INTERFACE PROGRAMMING 

The following subsections explain and illustrate all areas of 
interface programming. 

2.4.1 I/O Programming Introduction 

The SCC can work with three basic forms of I/O operations: 
polling, interrupts, and block transfer. All three I/O types 
involve register manipulation during initialization and 
data transfer. However, the interrupt mode also incorpo- 
rates Z-Bus interrupt protocol for a fast and efficient data 
transfer. 



Regardless of the version of the SCC, all communication 
modes can use a choice of polling, interrupt and block 
transfer. These modes are selected by the user to deter- 
mine the proper hardware and software required to supply 
data at the rate required. 

Note to ESCC Users: Those familiar with the NMOS/CMOS 
version will find the ESCC I/O operations very similar but 
should note the following differences: the addition of 
software acknowledge (which is available in the current 
version of the CMOS SCC, but not in NMOS); the /DTR//REQ 
pin can be programmed to be deasserted faster; and the 
programmability of the data interrupts to the FIFO fill level. 
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2.4.2 Polling 



2.4.3 Interrupts 



This is the simplest mode to implement. The software must 
poll the SCC to determine when data is to be input or output 
from the SCC. In this mode, MIE (WR9, bit 3), and Wait/ 
DMA Request Enable (WR1 , bit 7) are both reset to to 
disable any interrupt or DMA requests. The software must 
then poll RRO to determine the status of the receive buffer, 
transmit buffer and external status. 

During a polling sequence, the status of Read Register 
is examined in each channel. This register indicates whether 
or not a receive or transmit data transfer is needed and 
whether or not any special conditions are present, 
e.g., errors. 

This method of I/O transfer avoids interrupts and, conse- 
quently, all interrupt functions should be disabled. With no 
interrupts enabled, this mode of operation must initiate a 
read cycle of Read Register to detect an incoming 
character before jumping to a data handler routine. 



Each of the SCC's two channels contain three sources of 
interrupts, making a total of six interrupt sources. These 
three sources of interrupts are: 1 ) Receiver, 2) Transmitter, 
and 3) External/Status conditions. In addition, there are 
several conditions that may cause these interrupts. 
Figure 2-9 shows the different conditions for each interrupt 
source and each is enabled under program control. Chan- 
nel A has a higher priority than Channel B with Receive, 
Transmit, and External/Status Interrupts prioritized, re- 
spectively, within each channel as shown in Table 2-8. The 
SCC internally updates the interrupt status on every PCLK 
cycle in the Z85X30 and on /AS in the Z80X30. 

Table 2-8. Interrupt Source Priority 



Receive Channel A 
Transmit Channel A 
External/Status Channel A 
Receive Channel B 
Transmit Channel B 
External/Status Channel B 



Highest 



Lowest 



INT on first Rx Character 
or Special Condition 



Receive Character Available 



Receive Overrun 



Framing Error 



End of Frame (SDLC) 



Parity Error (If enabled) 




INT on all Rx Character 
or Special Condition 



Rx Interrupt on Special 
Condition Only 



Receiver 
Interrupt 
Sources 



Transmit Buffer Empty 



Transmitter 
Interrupt 
Source 



Zero Count 



DCD 



SYNC/HUNT 



CTS 



External/Status 
Interrupt 
Sources 



Tx Underrun/EOM 



Break/Abort 



► 


SCC 




Interrupt 



Figure 2-9. ESCC Interrupt Sources 
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ESCC: 

The receive interrupt request is either caused by a receive 
character available or a special condition. When the re- 
ceive character available interrupt is generated, it is de- 
pendent on WR7' bit D3. If WR7' 03=0 t the receive char- 
acter available interrupt is generated when one character 
is loaded into the FIFO and is ready to be read. If WR7' 
D3=1, the receive character available interrupt is gener- 
ated when four bytes are available to be read in the receive 
data FIFO. The programmed value of WR7' D5 also affects 
when DMA requests are generated. See Section 2.5 for 
details. 



The External/status interrupts have several sources which 
may be individually enabled in WR15. The sources are 
zero count, /DCD, Sync/Hunt, /CTS, transmitter underrun/ 
EOM and Break/Abort. 

2.4.4 Interrupt Control 

In addition to the MIE bit that enables or disables all SCC 
interrupts, each source of interrupt in the SCC has three 
control/status bits associated with it. They are the Interrupt 
Enable (IE), Interrupt Pending (IP), and Interrupt-Under- 
Service(IUS).ngure2-10showstheSCCinterruptstructure. 



Note: If the ESCC is used in SDLC mode, it enables the 
SDLC Status FIFO to affect how receive interrupts are 
generated. If this feature is used, read Section 4.4.3 on the 
SDLC Anti-Lock Feature. 

The special conditions are Receive FIFO overrun, 
CRC/framing error, end of frame, and parity. If parity is 
included as a special condition, it is dependent on WR1 
D2. The special condition status can be read from RR1 . 

On the NMOS/CMOS versions, set the IP bit whenever the 
transmit buffer becomes empty. This means that the trans- 
mit buffer was full before the transmit IP can be set. 

ESCC: 

The transmit interrupt request has only one source and is 
dependent on WR7' D5. If the IP bit WR7' D5=0, it is set 
when the transmit buffer becomes completely empty. If the 
IP bit WR7' D5= 1, the transmit interrupt is generated when 
the exit location of the FIFO is empty. Note that in both 
cases the transmit interrupt is not set until after the first 
character is written to the ESCC. 

For transmit Interrupt, see Section 2.4.8 for details. 



Interrupt Vector 
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Figure 2-10. Peripheral Interrupt Structure 



Figure 2-1 1 shows the internal priority resolution method to 
allow the highest priority interrupt to be serviced first. 
Lower priority devices on the external daisy chain can be 
prevented from requesting interrupts via the Disable Lower 
Chain bit in WR9 D2. 
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Figure 2-11. Internal Priority Resolution 
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2.4.4.1 Master Interrupt Enable Bit 

The Master Interrupt Enable (MIE) bit, WR9 D3, must be set 
to enable the SCC to generate Interrupts. The MIE bit 
should be set after intializing the SCC registers and en- 
abling the individual interrupt enables. The SCC requests 
an interrupt by asserting the /INT pin Low from its open- 
drain state only upon detection that one of the enabled 
interrupt conditions has been detected. 

2.4.4.2 Interrupt Enable Bit 

The Interrupt Enable (IE) bits control interrupt requests 
from each interrupt source on the SCC. If the IE bit is set 
to 1 for an interrupt source, that source may generate an 
interrupt request, providing all of the necessary conditions 
are met. If the IE bit is reset, no interrupt request is 
generated by that source. The transmit interrupt IE bit is 
WR1 D1 . The receive interrupt IE bits are WR1 D3 and D4. 
The external status interrupts are individually enabled in 
WR15 with the master external status interrupt enable in 
WR1 DO. Reminder: The MIE bit, WR9 D3, must be set for 
any interrupt to occur. 

2.4.4.3 Interrupt Pending Bit 

The Interrupt Pending (IP) bit for a given source of interrupt 
is set by the presence of an interrupt condition in the SCC. 
It is reset directly by the processor, or indirectly by some 
action that the processor may take. If the corresponding IE 
bit is not set, the IP for that source of interrupt will never be 
set. The IP bits in the SCC are read only via RR3 as shown 
in Figure 2-12. 



Read Register 3 

D7| D6 1 D5| D4| D3 1 D2 1 D1 | Dp| 

L— Channel B Ext/Status IP 

I Channel B Tx IP 

* Channel B Rx IP 

' Channel A Ext/Status IP 

' Channel A Tx IP 

' Channel A Rx IP 

I . 



* Always In B Channel 



2.4.4.4 Interrupt-Under-Service Bit 

The Interrupt-Under-Service (IUS) bits are completely 
hidden from the processor. An IUS bit is set during an 
interrupt acknowledge cycle for the highest priority IP. On 
the CMOS or ESCC the IUS bits can be set by either a 
hardware acknowledge cycle with the /INTACK pin or 
through software if WR9 D5=1 and then reading RR2. 

The IUS bits control the operation of internal and external 
daisy-chain interrupts. The internal daisy chain links the six 
sources of interrupt in a fixed order, chaining the IUS bit of 
each source. If an internal IUS bit is set, all lower priority 
interrupt requests are masked off; during an interrupt 
acknowledge cycle the IP bits are also gated into the daisy 
chain. This ensures that the highest priority IP selected has 
its IUS bit set. At the end of an interrupt service routine, the 
processor must issue a Reset Highest IUS command in 
WRO to re-enable lower priority interrupts. This is the only 
way, short of a software or hardware reset, that an IUS bit 
may be reset. 

Note: It is not necessary to issue the Reset Highest IUS 
command in the interrupt service routine, since the IUS bits 
can only be set by an interrupt acknowledge if no hardware 
acknowledge or software acknowledge cycle (not with 
NMOS) is executed. The only exception is when the SDLC 
Frame Status FIFO (not with NMOS) is enabled and "re- 
ceive interrupt on special condition only" is used. See 
section 4.4.3 for more details on this mode. 

2.4.4.5 Disable Lower Chain Bit 

The Disable Lower Chain (DLC) bit in WR9 (D2) is used to 
disable all peripherals in a lower position on the external 
daisy chain. If WR9 D2=1 , the IEO pin is driven Low and 
prevents lower priority devices from generating an inter- 
rupt request. Note that the IUS bit, when set, will have the 
same effect, but is not controllable through software. 



Figure 2-12. RR3 Interrupt Pending Bits 
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2.4.5 Daisy-Chain Resolution 



The six sources of interrupt in the SCC are prioritized in a 
fixed order via a daisy chain; provision is made, via the IEI 
and IEO pins, for use of an external daisy chain as well. All 
Channel A interrupts are higher priority than any 
Channel B interrupts, with the receiver, transmitter, and 
External/Status interrupts prioritized in that order within 
each channel. The SCC requests an interrupt by pulling 
the /INT pin Low from its open-drain state. This is controlled 
by the IP bits and the IEI input, among other things. A 
flowchart of the interrupt sequence for the SCC is shown in 
Figure 2-13. 

The internal daisy chain links the six sources of interrupt in 
a fixed order, chaining the IUS bits for each source. While 
an IUS bit is set, all lower priority interrupt requests are 
masked off, thus preventing lower priority interrupts, but 
still allowing higher priority interrupts to occur. Also, during 
an interrupt acknowledge cycle the IP bits are gated into 
the daisy chain. This insures that the highest priority IP is 
selected to set IUS. The internal daisy chain may be 
controlled by the MIE bit in WR9. This bit, when reset, has 
the same effect as pulling the IEI pin Low, thus disabling all 
interrupt requests. 

2.4.5.1 External Daisy-Chain Operations 
The SCC generates an interrupt request by pulling /INT 
Low, but only if such interrupt requests are enabled 
(IE is 1 , MIE is 1 ) and all of the following conditions occur: 

■ IP is set without a higher priority IUS being set 

■ No higher priority IUS is being set 

■ No higher priority interrupt is being serviced 
(IEI is High) 

■ No interrupt acknowledge transaction is 
taking place 

IEO is not pulled Low by the SCC at this time, but instead 
continues to. follow IEI until an interrupt acknowledge 
transaction occurs. Some time after /INT has been pulled 
Low, the processor initiates an Interrupt Acknowledge 
transaction. Between the time the SCC recognizes that an 
Interrupt Acknowledge cycle is in progress and the time 
during the acknowledge that the processor requests an 



interrupt vector, the IEI/IEO daisy chain settles. Any pe- 
ripheral in the daisy chain having an Interrupt Pending (IP 
is 1) or an Interrupt-Under-Service (IUS is 1) holds its IEO 
line Low and all others make IEO follow IEI. 

When the processor requests an interrupt vector, only the 
highest priority interrupt source with a pending interrupt 
(IP is 1 ) has its IEI input High, its IE bit set to 1 , and its IUS 
bit set to 0. This is the interrupt source being acknowl- 
edged, and at this point it sets its IUS bit to 1 . If its NV bit 
is 0, the SCC identifies itself by placing the interrupt vector 
from WR2 on the data bus. If the NV bit is 1 , the SCC data 
bus remains floating, allowing external logic to supply a 
vector. If the VIS bit in the SCC is 1 , the vector also contains 
status information, encoded as shown in Table 2-9, which 
further describes the nature of the SCC interrupt. 



Table 2-9. Interrupt Vector Modification 



V3 


V2 


V1 


Status High/Status Low = 


V4 


V5 


V6 


Status High/Status Low = 1 











Ch B Transmit Buffer Empty 








1 


Ch B External/Status Change 





1 





Ch B Receive Character Avail 





1 


1 


Ch B Special Receive Condition 


1 








Ch A Transmit Buffer Empty 


1 





1 


Ch A External/Status Change 


1 


1 





Ch A Receive Character Avail 


1 


1 


1 
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If the VIS bit is 0, the vector held in WR2 is returned without 
modification. If the SCC is programmed to include status 
information in the vector, this status may be encoded and 
placed in either bits 1-3 or in bits 4-6. This operation is 
selected by programming the Status High/Status Low bit in 
WR9. At the end of the interrupt service routine, the 
processor should issue the Reset Highest IUS command 
to unlock the daisy chain and allow lower priority interrupt 
requests. The IP is reset during the interrupt service 
routine, either directly by command or indirectly through 
some action taken by the processor. The external daisy 
chain may be controlled by the DLC bit in WR9. This bit, 
when set, forces IEO Low, disabling all lower priority 
devices. 
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Interrupt Pending 
Set(IP=1) 




Peripheral Requests 
Interrupt (INT=L) 



CPU Initiates Status 
Decode (INTACK=L) 



IEI/IEO Daisy Chain 
Settles (Wait for PS) 




Figure 2-13. Interrupt Flow Chart (for each interrupt source). 



2.4.6 Interrupt Acknowledge 



The SCC is flexible with its interrupt method. The interrupt 
may be acknowledged with a vector transferred, ac- 
knowledged without a vector, or not acknowledged at all. 

2.4.6.1 Interrupt Without Acknowledge 

In this mode, the Interrupt Acknowledge signal does not 
have to be generated. This allows a simpler hardware 
design that does not have to meet the interrupt acknowl- 
edge timing. Soon after the INT goes active, the interrupt 
controller jumps to the interrupt routine. In the interrupt 
routine, the code must read RR2 from Channel B to read 
the vector including status. When the vector is read from 
Channel B, it always includes the status regardless of the 
VIS bit (WR9 bit 0). The status given will decode the highest 
priority interrupt pending at the time it is read. The vector 
is not latched so that the next read could produce a 
different vector if another interrupt occurs. The register is 
disabled from change during the read operation to prevent 
an error if a higher interrupt occurs exactly during the read 
operation. 

Once the status is read, the interrupt routine must decode 
the interrupt pending, and clear the condition. Removing 
the interrupt condition clears the IP and brings /INT inac- 
tive (open drain), as long as there are no other IP bits set. 
For example, writing a character to the transmit buffer 
clears the transmit buffer empty IP. 

When the interrupt IP, decoded from the status, is cleared, 
RR2 can be read again. This allows the interrupt routine to 
clear all of the IP's within one interrupt request to the CPU. 

2.4.6.2 Interrupt With Acknowledge 

After the SCC brings/INT active, the CPU can respond with 
a hardware acknowledge cycle by bringing /INTACK ac- 
tive. After enough time has elapsed to allow the daisy chain 
to settle (see AC Spec #38), the SCC sets the IUS bit for the 
highest priority IP. If the No Vector bit is reset (WR9 D1 =0), 
the SCC then places the interrupt vector on the data bus 
during a read. To speed the interrupt response time, the 
SCC can modify 3 bits in the vector to indicate the source 
of the interrupt. To include the status, the VIS bit, WR9 DO, 
is set. The service routine must then clear the interrupting 
condition. For example, writing a character to the transmit 
buffer clears the transmit buffer empty IP. After the inter- 



rupting condition is cleared, the routine can read RR3 to 
determine if any other IP's are set and take the appropriate 
action to clear them. At the end of the interrupt routine, a 
Reset IUS command (WRO) is issued to unlock the daisy 
chain and allow lower-priority interrupt requests. This is the 
only way, short of a software or hardware reset, that an IUS 
bit is reset. 

If the No Vector bit is set (WR9 D1=1), the SCC will not 
place the vector on the data bus. An interrupt controller 
must then vector the code to the interrupt routine. The 
interrupt routine reads RR2 from Channel B to read the 
status. This is similar to an interrupt without an acknowl- 
edge, except the IUS is set and the vector will not change 
until the Reset IUS command in RRO is issued. 

2.4.6.3 Software Interrupt Acknowledge (CMOS/ESCC) 

An interrupt acknowledge cycle can be done in software 
for those applications which use an external interrupt 
controller or which cannot generate the /INTACK signal 
with the required timing. If WR9 D5 is set, reading register 
two, RR2, results in an interrupt acknowledge cycle to be 
executed internally. Like a hardware INTACK cycle, 
a software acknowledge causes the /INT pin to return 
High, the IEO pin to go Low and the IUS latch to be set for 
the highest priority interrupt pending. 

As when the hardware /INTACK signal is used, a software 
acknowledge cycle requires that a Reset Highest IUS 
command be issued in the interrupt service routine. If RR2 
is read from Channel A, the unmodified vector is returned. 
If RR2 is read from Channel B, then the vector is modified 
to indicate the source of the interrupt. The Vector Includes 
Status (VIS) and No Vector (NV) bits in WR9 are ignored 
when bit D5 is set to 1 . 

2.4.7 The Receiver Interrupt 

The sources of receive interrupts consist of Receive Char- 
acter Available and Special Receive Condition. The Spe- 
cial Receive Condition can be subdivided into Receive 
Overrun, Framing Error (Asynchronous) or End of Frame 
(SDLC). In addition, a parity error can be a special receive 
condition by programming. 
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As shown in Figure 2-14, Receive Interrupt mode is con- 
trolled by three bits in WR1 . Two of these bits, D4 and D3, 
select the interrupt mode; the third bit, D2, is a modifier for 
the various modes. On the ESCC, WR7' bit D2 affects the 
receiver interrupt operation mode as well. If the interrupt 
capability of the receiver in the SCC is not required, polling 
may be. used. This is selected by disabling receive inter- 
rupts and polling the Receiver Character Available bit in 
RRO. When this bit indicates that a received character has 



reached the exit location (CPU side) of the FIFO, the status 
in RR1 should be checked and then the data should be 
read. If status is checked, it must be done before the data 
is read, because the act of reading the data pops both the 
data and error FIFOs. Another way of polling SCC is to 
enable one of the interrupt modes and then reset the MIE 
bit in WR9. The processor may then poll the IP bits in RR3A 
to determine when receive characters are available. 



WR1 









D4 


D3 


D2 








T 



Parity is special condition 

00 Receive Interrupt Disabled 

01 Rx INT On First Character or Special Condition 

1 Rx INT On All Receive Characters or Special Condition 

1 1 Rx INT On Special Condition Only 



Figure 2-14. Write Register 1 Receive Interrupt Mode Control 



2.4.7.1 Receive Interrupt on the ESCC 

On the ESCC, one other bit, WR7' bit D2, also affects the 
interrupt operation. 

WR7' D3=0, a receive interrupt is generated when one 
byte is available in the FIFO. This mode is selected after 
reset and maintains compatibility with the SCC. Systems 
with a long interrupt response time can use this mode to 
generate an interrupt when one byte is received, but still 
allow up to seven more bytes to be received without an 
overrun error. By polling the Receive Character Available 
bit, RRO DO, and reading all available data to empty the 
FIFO before exiting the interrupt service routine, the fre- 
quency of interrupts can be minimized. 

WR7' D3=1, the ESCC generates an interrupt when there 
are four bytes in the Receive FIFO or when a special 
condition is received . By setting this bit, the ESCC generates 
a receive interrupt when four bytes are available to read 
from the FIFO. This allows the CPU not to be interrupted 
until at least four bytes can be read from the FIFO, thereby 
minimizing the frequency of receive interrupts. If four or 
more bytes remain in the FIFO when the Reset Highest IUS 
command is issued at the end of the service routine, 
another receive interrupt is generated. 

When a special receive condition is detected in the top four 
bytes, a special receive condition interrupt is generated 
immediately. This feature is intended to be used with the 
Interrupt On All Receive Characters and Special Condition 
mode. This is especially useful in SDLC mode because the 
characters are contiguous and the reception of the closing 
flag immediately generates a special receive interrupt. 
The generation of receive interrupts is described in the 
following two cases: 



Case 1 : Four Bytes Received with No Errors. A receive 
character available interrupt is triggered when the four 
bytes in receive data FIFO (from the exit side) are full 
and no special conditions have been detected. There- 
fore, the interrupt service routine can read four bytes 
from the data FIFO without having to read RR1 to 
check for error conditions. 

Case 2: Data Received with Error Conditions. When 
any of the four bytes from the exit side in the receive 
error FIFO indicate an error has been detected, a 
Special Receive condition interrupt is triggered with- 
out waiting for the byte to reach the top of the FIFO. In 
this case, the interrupt service routine must read RR1 
first before reading each data byte to determine which 
byte has the special receive condition and then take 
the appropriate action. Since, in this mode, the status 
must be checked before the data is read, the data 
FIFO is not locked and the Error Reset command is not 
necessary. 

Note: The above cases assume that the receive I US bit 
is reset to zero in order for an interrupt to be generated. 

WR7' D3 should be written zero when using Interrupt 
on First Character and Special Condition or Interrupt 
on Special Condition Only. See the description for 
Interrupt on All Characters or Special Condition mode 
for more details on this feature. 

Note: The Receive Character Available Status bit, RRO 
DO, indicates if at least one byte is available in the 
Receive FIFO, independent of WR7' D3. Therefore, 
this bit can be polled at any time for status if there is 
data in the Receive FIFO. 
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2.4.7.2 Receive Interrupts Disabled 

This mode prevents the receiver from requesting an inter- 
rupt. It is used in a polled environment where either the 
status bits in RRO or the modified vector in RR2 (Channel 
B) is read. Although the receiver interrupts are disabled, 
the interrupt logic can still be used to provide status. 

When these bits indicate that a received character has 
reached the exit location of the FIFO, the status in RR1 
should be checked and then the data should be read. If 
status is to be checked, it must be done before the data is 
read, because the act of reading the data pops both the 
data and error FIFOs. 

2.4.7.3 Receive Interrupt on First Character 
or Special Condition 

This mode is designed for use with DMA transfers of the 
receive characters. The processor is interrupted when the 
SCC receives the first character of a block of data. It reads 
the character and then turns control over to a DMA device 
to transfer the remaining characters. After this mode is 
selected, the first character received, or the first character 
already stored in the FIFO, sets the receiver IP. This IP is 
reset when this character is removed from the SCC. 

No further receive interrupts occur until the processor 
issues an Enable Interrupt on Next Receive Character 
command in WRO or until a special receive condition 
occurs. The correct sequence of events when using this 
mode is to first select the mode and wait for the receive 
character available interrupt. When the interrupt occurs, 
the processor should read the character and then enable 
the DMA to transfer the remaining characters. 

ESCC: 

WR7' bit D3 should be reset to zero in this mode. 

A special receive condition interrupt may occur any time 
after the first character is received, but is guaranteed to 
occur after the character having the special condition has 
been read. The status is not lost in this case, however, 
because the FIFO is locked by the special condition. In the 
interrupt service routine, the processor should read RR1 to 
obtain the status, and may read the data again if neces- 
sary. The FIFO is unlocked by issuing an Error Reset 
command in WRO. If the special condition was End-of- 
Frame, the processor should now issue the Enable Inter- 
rupt on Next Receive Character command to prepare for 
the next frame. The first character interrupt and special 
condition interrupt are distinguished by the status in- 
cluded in the interrupt vector. In all other respects they are 
identical, including sharing the IP and IUS bits. 



2.4.7.4 Interrupt on All Receive Characters or Special 
Condition 

This mode is designed for an interrupt driven system. In 
this mode, the NMOS/CMOS version and the ESCC with 
WR7' D3=0 sets the receive IP when a received character 
is shifted into the exit location of the FIFO. This occurs 
whether or not it has a special receive condition. This 
includes characters already in the FIFO when this mode is 
selected. In this mode of operation the IP is reset when the 
character is removed from the FIFO, so if the processor 
requires status for any characters, this status must be read 
before the data is removed from the FIFO. 

On the ESCC with D3=1 , four bytes are accumulated in the 
Receive FIFO before an interrupt is generated (IP is set), 
and reset when the number of the characters in the FIFO 
is less than four. 

The special receive conditions are identical to those pre- 
viously mentioned, and as before, the only difference 
between a "receive character available" interrupt and a 
"special receive condition" interrupt is the status encoded 
in the vector. In this mode a special receive condition does 
not lock the receive data FIFO so that the service routine 
must read the status in RR1 before reading the data. 

At moderate to high data rates where the interrupt over- 
head is significant, time can usually be saved by checking 
for another character before exiting the service routine. 
This technique eliminates the interrupt acknowledge and 
the status processing, saving time, but care must be 
exercised because this receive character must be checked 
for special receive conditions before it is removed from 
the SCC. 

2.4.7.5 Receive Interrupt on Special Conditions 

This mode is designed for use when a DMA transfers all 
receive characters between memory and the SCC. In this 
mode, only receive characters with special conditions will 
cause the receive IP to be set. All other characters are 
assumed to be transferred via DMA. No special initialization 
sequence is needed in this mode. Usually, the DMA is 
initialized and enabled, then this mode is selected in the 
SCC. A special receive condition interrupt may occur at 
anytime after this mode is selected, but the logic guarantees 
that the interrupt will not occur until after the character with 
the special condition has been read from the SCC. The 
special condition locks the FIFO so that the status is valid 
when read in the interrupt service routine, and it guaran- 
tees that the DMA will not transfer any characters until the 
special condition has been serviced. 
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In the service routine, the processor should read RR1 to 
obtain the status and unlock the FIFO by issuing an Error 
Reset command. DMA transfer of the receive characters 
then resumes. Figure 2-15 shows the special conditions 
interrupt service routine. 

Note: On the CMOS and ESCC, if the SDLC Frame Status 
FIFO is being used, please refer to Section 4.4.3 on the 
FIFO anti-lock feature. 

Note: Special Receive Condition interrupts are generated 
after the character is read from the FIFO, r?of when the 
special condition is first detected. This is done so that 
when using receive interrupt on first or Special Condition 
or Special Condition Only, data is directly read out of the 



data FIFO without checking the status first. If a special 
condition interrupted the CPU when first detected, it would 
be necessary to read RR1 before each byte in the FIFO to 
determine which byte had the special condition. There- 
fore, by not generating the interrupt until after the byte has 
been read and then locking the FIFO, only one status read 
is necessary. A DMA can be used to do all data transfers 
(otherwise, it would be necessary to disable the DMA to 
allow the CPU to read the status on each byte). Conse- 
quently, since the special condition locks the FIFO to 
preserve the status, it is necessary to issue the Error Reset 
command to unlock it. Only the exit location of the FIFO is 
locked allowing more data to be received into the other 
bytes of the Receive FIFO. 
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2.4.8 Transmit Interrupts and Transmit Buffer 
Empty Bit 

Transmit interrupts are controlled by Transmit Interrupt 
Enable bit (D1) in WR1. If the interrupt capabilities of the 
SCC are not required, polling may be used. This is se- 
lected by disabling transmit interrupts and polling the 
Transmit Buffer Empty bit (TBE) in RRO. When the TBE bit 
is set, a character may be written to the SCC without fear 
of writing over previous data. Another way of polling the 
SCC is to enable transmit interrupts and then reset Master 
Interrupt Enable bit (MIE) in WR9. The processor may then 
poll the IP bits in RR3A to determine when the transmit 
buffer is empty. Transmit interrupts should also 
be disabled in the case of DMA transfer of the 
transmitted data. 

Because the depth of the transmitter buffer is different 
between the NMOS/CMOS version of the SCC and ESCC, 
generation of the transmit interrupt is slightly different. The 
following subsections describe transmit interrupts. 

Note: For all interrupt sources, the Master Interrupt Enable 
(MIE) bit, WR9 bit D3, must be set for the device to 
generate a transmit interrupt. 

2.4.8.1 Transmit Interrupts and Transmit Buffer Empty Bit 
on the NMOS/CMOS 

The NMOS/CMOS version of the SCC only has a one byte 
deep transmit buffer. The status of the transmit buffer can 
be determined through TBE bit in RRO, bit D2, which shows 
whether the transmit buffer is empty or not. After a hard- 
ware reset (including a hardware reset by software), or a 
channel reset, this bit is set to 1 . 

While transmit interrupts are enabled, the NMOS/CMOS 
version sets the Transmit Interrupt Pending (TxlP) bit 
whenever the transmit buffer becomes empty. This means 
that the transmit buffer must be full before the TxlP can be 
set. Thus, when transmit interrupts are first enabled, the 
TxlP will not be set until after the first character is written to 
the NMOS/CMOS. In synchronous modes, one other con- 
dition can cause the TxlP to be set. This occurs at the end 
of a transmission after the CRC is sent. When the last bit of 
the CRC has cleared the Transmit Shift Register and the 
flag or sync character is loaded into the Transmit Shift 
Register, the NMOS/CMOS version sets the TxlP and TBE 
bit. Data for a second frame or block transmission may be 
written at this time. 

The TxlP is reset either by writing data to the transmit buffer 
or by issuing the Reset Tx Int command in WRO. Ordinarily, 
the response to a transmit interrupt is to write more data to 
the device; however, the Reset Tx Int command should be 
issued in lieu of data at the end of a frame or a block of data 
where the CRC is to be sent next. 



Note: A transmit interrupt may indicate that the packet has 
terminated illegally, with the CRC byte(s) overwritten by 
the data. If the transmit interrupt occurs after the first CRC 
byte is loaded into the Transmit Shift Register, but before 
the last bit of the second CRC byte has cleared the 
Transmit Shift Register, then data was written while the 
CRC was being sent. 

2.4.8.2 Transmit Interrupt and Transmit Buffer Empty bit 
on the ESCC 

The ESCC has a four byte deep Transmit FIFO where the 
NMOS/CMOS version is just one byte deep. Consequently, 
the generation of transmit interrupts is slightly different 
from the NMOS/CMOS version. The ESCC has two modes 
of transmit interrupt generation, which are programmed by 
D5 of WR7' . One transmit mode generates interrupts when 
the entry location (the location the CPU writes data) of the 
Transmit FIFO is empty, and the other generates interrupts 
when the FIFO is completely empty. This allows the ESCC 
response to be tailored to system requirements for the 
frequency of interrupts and the interrupt response time. 

When WR7' D5=1 (the default case), the ESCC generates 
a transmit interrupt when the Transmit FIFO is completely 
empty. The transmit data interrupt is generated when the 
exit location of the Transmit FIFO loads into the Transmit 
Shift Register and the FIFO becomes empty. WR7' bit D5 
is set to one by a hardware or channel reset. This mode 
minimizes the frequency of transmit interrupts by writing 
four bytes to the Transmit FIFO on each entry to the 
interrupt service routine. The TBE bit, RRO bit D2, is set 
when at least one byte can be written to the Transmit FIFO. 
Therefore, this bit may be polled at any time to determine 
if a byte can be written. 

When WR7' D5=0, the TxlP bit is set when the entry location 
of the Transmit FIFO is empty. This mode provides a 
system which cannot respond to an interrupt in one char- 
acter transmission time (a long latency time to respond 
before the transmitter underruns.) 

Note: When WR7' D5=0, TBE bit and transmit interrupt are 
reset momentarily when data is loaded into the entry 
location of the Transmit FIFO. Transmit interrupt is not 
generated when the entry location of the Transmit FIFO is 
filled. The TBE bit is set and transmit interrupt is generated 
again when the data is pushed down the FIFO and the 
entry location becomes empty (approximately one PCLK 
time). 

Note: When WR7' D5=0, only one byte is written to the FIFO 
and three or fewer bytes are in the FIFO, the ESCC 
generates multiple interrupts until the FIFO is filled. There- 
fore, by polling the TBE bit (RRO D2) after writing each byte, 
multiple interrupts to fill the FIFO are avoided. 
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While transmit interrupts are enabled, the ESCC sets the 
TxlP when the transmit buffer reaches the condition pro- 
grammed in WR7' bit D5. This means that the transmit 
buffer must have been written before the TxlP is set. Thus, 
when transmit interrupts are first enabled, the transmit IP is 
not set until the programmed interrupting condition is met. 

The Tx IP is reset either by writing data to the transmit buffer 
or by issuing the Reset Tx Int Pending command in WRO. 
Ordinarily, the response to a transmit interrupt is to write 
more data to the ESCC; however, if there is no more data 
to be transmitted at that time, it is the end of the frame. The 
Reset Tx Int Pending command is used to reset the TxlP 
and clear the interrupt. For example, at the end of a frame 
or block of data where the CRC is to be sent next, the Reset 
Tx Int Pending command should be issued after the last 
byte of data has been written to the ESCC. 

On the ESCC, TBE bit is not directly related to the transmit 
interrupt status or the state of WR7' bit D5, but it shows the 
status of the exit location of the Transmit FIFO. This 
indicates that more characters can be written to the Trans- 
mit FIFO without being overwritten, which allows the inter- 
rupt/polling handling routine to write more than one byte to 
fill up the FIFO. 

In synchronous modes, one other condition can cause the 
TxlP to be set. This occurs at the end of a transmission after 
the CRC is sent. When the last bit of the CRC has cleared 



the Transmit Shift Register and the flag or sync character 
is loaded into the Transmit Shift Register, the ESCC sets 
the TxlP. Data for the new frame or block to be transmitted 
may be written at this time. In this particular case, the 
Transmit Buffer Empty bit in RRO and the TxlP are set. 

An enhancement to the ESCC from the NMOS/CMOS 
version is that the CRC has priority over the data, where on 
the NMOS/CMOS version data has priority over the CRC 
bytes. This means on the ESCC the CRC bytes are guar- 
anteed to be sent, even if the data for the next packet has 
written before the second transmit interrupt, but after the 
EOM/Underrun condition exists. This helps to increase the 
system throughput because there is no waiting for the 
second transmit interrupt. On the NMOS/CMOS version, if 
the data is written while the CRC is sent, CRC byte(s) are 
replaced with the flag/sync pattern followed by the data. 

Another enhancement of the ESCC is that it latches the 
transmit interrupt because the CRC is loaded into the 
Transmit Shift Register even if the transmit interrupt, due to 
the last data byte, is not yet reset. Therefore, the end of a 
synchronous frame is guaranteed to generate two transmit 
interrupts even if a Reset Tx Int Pending command for the 
data created interrupt is issued after (Time "A" in 
Figure 2-16) the CRC interrupt had occurred. In this case, 
two reset Tx Int Pending commands are required. The TxlP 
is latched if the EOM latch has been reset before the end 
of the frame. 
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Figure 2-16. TxlP Latching on the ESCC 
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2.4.8.3 Transmit Interrupt and Tx Underrun/EOM bit in 
synchronous modes 

As described in the section above, the behavior of the 
NMOS/CMOS version and the ESCC is slightly different, 
particularly at the end of packet sending. On the NMOS/ 
CMOS version, the data has higher priority over CRC data; 
writing data before this interrupt would terminate the packet 
illegally. In this case, the CRC byte(s) are replaced with a 
Flag or Sync pattern, followed by the data written. On the 
ESCC, the CRC has priority over the data. That means after 



the reception of the Underrun/EOM (End Of Message) 
interrupt, it accepts the data for the next packet without 
collapsing the packet. On the ESCC, if data was written 
during the time period described above, the TBE bit (bit D2 
of RRO) will not be set even if the second TxlP is guaranteed 
to set when the flag/sync pattern was loaded into the 
Transmit Shift Register, as mentioned above (Figures 2-1 7 
and 18). Hence, on the ESCC, there is no need to wait for 
the second TxlP bit to set before writing data for the next 
packet and reducing the overhead. 
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Figure 2-17. Operation of TBE, Tx Underrun/EOM and TxlP on NMOS/CMOS. 
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Figure 2-18. Operation of TBE, Tx Underrun/EOM and TxlP on ESCC. 
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An example flowchart for processing an end of packet is 
shown in Figure 2-1 9. The chart includes the differences in 
processing between the ESCC and NMOS/CMOS version. 
In this chart, Tx IP and Underrun/EOM INT can be pro- 
cessed by interrupts or by polling the registers. Note that 



this flowchart does not have the procedures for interrupt 
handling, such as saving/restoring of registers to be used 
in the ISR (Interrupt Service Routine), Reset IUS command, 
or return from interrupt sequence. 
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Figure 2-19. Flowchart example of processing an end of packet 
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2.4.9 External/Status Interrupts 



Each channel has six external/status interrupt conditions: 
BRG Zero Count, Data Carrier Detect, Sync/Hunt, Clear to 
Send, Tx Underrun/EOM, and Break/Abort. The master 
enable for external/status interrupts is DO of WR1 , and the 
individual enable bits are in WR15. Individual enable bits 
control whether or not a latch is present in the path from the 
source of the interrupt to the corresponding status bit in 
RRO. If the individual enable is set to 0, then RRO reflects 
the current unlatched status, and if the individual enable is 
set to 1 , then RRO reflects the latched status. 

The latches for the external/status interrupts are not inde- 
pendent. Rather, they all close at the same time as a result 
of a state change in one of the sources of enabled external/ 
status interrupts. This is shown schematically in 
Figure 2-20. 



The External/Status IP is set by the closing of the latches 
and remains set as long as they are closed. In order to 
determine which condition(s) require service when an 
external/status interrupt is received, the processor should 
keep an image of RRO in memory and update this image 
each time it executes the external/status service routine. 

Thus, a read of RRO returns the current status for any bits 
whose individual enable is 0, and either the current state or 
the latched state of the remainder of the bits. To guarantee 
the current status, the processor should issue a Reset 
External/Status interrupts command in WRO to open the 
latches. The External/Status IP is set by the closing of the 
latches and remains set as long as they are closed. If the 
master enable for the External/Status interrupts is not set, 
the IP is never set, even though the latches may be present 
in the signal paths and working as described. 
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Figure 2-20. RRO External/Status Interrupt Operation 
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Because the latches close on the current status, but give 
no indication of change, the processor must maintain a 
copy of RRO in memory. When the SCC generates an 
External/Status Interrupt, the processor should read RRO 
and determine which condition changed state and take 
appropriate action. The copy of RRO in memory is then 
updated and the Reset External/Status Interrupt command 
issued. Care must be taken in writing the interrupt service 
routine for the External/Status interrupts because it is 
possible for more than one status condition to change 
state at the same time. All of the latch bits in RRO should be 
compared to the copy of RRO in memory. If none have 
changed and the ZC interrupt is enabled, the Zero Count 
condition caused the interrupt. 

On the ESCC, the contents of RRO are latched while 
reading this register. The ESCC prevents the contents of 
RRO from changing while the read cycle is active. On the 
NMOS/CMOS version, it is possible for the status of RRO to 
change while a read is in progress, so it is necessary to 
read RRO twice to detect changes that otherwise may be 
missed. The contents of RRO are latched on the falling 
edge of /RD and are updated after the rising edge of /RD. 

The operation of the individual enable bits in WR15 for 
each of the six sources of External/Status interrupts is 
identical, but subtle differences exist in the operation of 
each source of interrupt. The six sources are Break/Abort, 
Underrun/EOM, CTS, DCD, Sync/Hunt and Zero Count. 
The Break/Abort, Underrun/EOM, and Zero Count condi- 
tions are internal to the SCC, while Sync/Hunt may be 
internal or external, and CTS and DCD are purely external 
signals. In the following discussions, each source is as- 
sumed to be enabled so that the latches are present and 
the External/Status interrupts are enabled as a whole. 
Recall that the External/Status IP is set while the latches are 
closed and that the state of the signal is reflected immedi- 
ately in RRO if the latches are not present. 

2.4.9.1 Break/Abort 

The Break/Abort status is used in asynchronous and SDLC 
modes, but is always in synchronous modes other than 
SDLC. In asynchronous modes, this bit is set when a break 
sequence (null character plus framing error) is detected in 
the receive data stream, and remains set as long as Os 
continue to be received. This bit is reset when a 1 is 
received. A single null character is left in the Receive FIFO 
each time that the break condition is terminated. This 
character should be read and discarded. 

In SDLC mode, this bit is set by the detection of an abort 
sequence which is seven or more contiguous 1s in the 
receive data stream. The bit is reset when a is received. 
A received abort forces the receiver into Hunt, which is also 



an external/status condition. Though these two bits change 
state at roughly the same time, one or two External/Status 
Interrupts may be generated as a result. The Break/Abort 
bit is unique in that both transitions are guaranteed to 
cause the latches to close, even if another External/Status 
interrupt is pending atthe time these transitions occur. This 
guarantees that a break or abort will be caught. This bit is 
undetermined after reset. 

2.4.9.2 Transmit Underrun/EOM 

The Transmit Underrun/EOM bit is used in synchronous 
modes to control the transmission of the CRC. This bit is 
reset by issuing the Reset Transmit Underrun/EOM com- 
mand in WRO. However, this transition does not cause the 
latches to close; this occurs only when the bit is set. To 
inform the processor of this fact, the SCC sets this bit when 
the CRC is loaded into the Transmit Shift Register. This bit 
is also set if the processor issues the Send Abort command 
in WRO. This bit is always set in Asynchronous mode. 

ESCC: 

The ESCC has been modified so that in SDLC mode this 
interrupt indicates when more data can be written to the 
Transmit FIFO. When this interrupt is used in this way, the 
Automatic SDLC Flag Transmission feature must be en- 
abled (WRT D0=1). On the NMOS/CMOS version, it is 
necessary to wait for the transmit buffer empty interrupt 
that is generated when the CRC transmission is completed 
before more data is written to the transmit buffer. However, 
on the ESCC, the Transmit Underrun/EOM interrupt can be 
used to signal when data for a subsequent frame can be 
written to the Transmit FIFO which more easily supports the 
transmission of back to back frames. 

2.4.9.3 CTS/DCD 

The CTS bit reports the state of the /CTS input, and the DCD 
bit reports the status of the /DCD input. Both bits latch on 
either inputtransition. In both cases, after the Reset External/ 
Status Interrupt command is issued, if the latches are 
closed, they remain closed if there is any odd number of 
transitions on an input; they open if there is an even number 
of transitions on the input. 

2.4.9.4 Zero Count 

The Zero Count bit is set when the counter in the baud rate 
generator reaches a count of and is reset when the 
counter is reloaded. The latches are closed only when this 
bit is set to 1 . The status in RRO always reflects the current 
status. While the Zero count IE bit in WR15 is reset, this bit 
is forced to 0. 
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2.4.9.5 Sync/Hunt 

There are a variety of ways in which the Sync/Hunt may be 
set and reset, depending on the SCC's mode of operation. 
In the Asynchronous mode this bit reports the state of the 
/SYNC pin, latching on both input transitions. The same is 
true of External Sync mode. However, if the crystal oscilla- 
tor is enabled while in Asynchronous mode, this bit will be 
forced to and the latches will not be closed . Selecting the 
crystal option in External Sync mode is illegal, but the result 
will be the same. 

In Synchronous modes other than SDLC, the Sync/Hunt 
reports the Hunt state of the receiver. Hunt mode is entered 
when the processor issues the Enter Hunt command in 
WR3. This forces the receiver to search for a sync charac- 
ter match in the receive data stream. Because both transi- 
tions of the Hunt bit close the latches, issuing this com- 
mand will cause an External/Status interrupt. The SCC 
resets this bit when character synchronization has been 
achieved, causing the latches to again be closed. 

In these synchronous modes, the SCC will not re-enter the 
Hunt mode automatically; only the Enter Hunt command 
will set this bit. In SDLC mode this bit is also set by the Enter 



2.5 BLOCK/DMA TRANSFER 

The SCC provides a Block Transfer mode to accommo- 
date CPU block transfer functions and DMA controllers. 
The Block Transfer mode uses the /W//REQ output in 
conjunction with the Wait/Request bits in Write Register 1 . 
The/W//REQ output can be defined by software as a /WAIT 
line in the CPU BlockTransfer mode or as a/REQ line in the 
DMA Block Transfer mode. The /DTR//REQ pin can also be 
programmed through WR14 bit D2 to function as a DMA 
request for the transmitter. 

To a DMA controller, the SCC's /REQ outputs indicate that 
the SCC is ready to transfer data to or from memory. To the 
CPU, the /WAIT output indicates that the SCC is not ready 
to transfer data, thereby requesting the CPU to extend the 
I/O cycle. 



Hunt command, but the receiver automatically enters the 
Hunt mode if an Abort sequence is received. The receiver 
leaves Hunt upon receipt of a flag sequence. Both transitions 
of the Hunt bit will cause the latches to be closed. In SDLC 
mode, the receiver automatically synchronizes on Flag 
characters. The receiver is in Hunt mode when it is enabled, 
so the Enter Hunt command is never needed. 

2.4.9.6 External/Status Interrupt Handling 
If careful attention is paid to details, the interrupt service 
routine for External/Status interrupts is straightforward. To 
determine which bit or bits changed state, the routine 
should first read RRO and compare it to a copy from 
memory. For each changed bit, the appropriate action 
should be taken and the copy in memory updated. The 
service routine should close with two Reset External/Status 
interrupt commands to reopen the latches. The copy of 
RRO in memory should always have the Zero Count bit set 
to 0, since this is the state of the bit after the Reset External/ 
Status interrupts command at the end of the service 
routine. When the processor issues the Reset Transmit 
Underrun/EOM latch command in WRO, the Transmit 
Underrun/EOM bit in the copy of RRO in memory should be 
reset because this transition does not cause an interrupt. 



2.5.1 Block Transfers 

The SCC offers several alternatives for the block transfer of 
data. The various options are selected by WR1 (bits D7 
through D5) and WR14 (bit D2). Each channel in the SCC 
has two pins which are used to control the block transfer of 
data. Both pins in each channel may be programmed to 
act as DMA Request signals. The /W//REQ pin in each 
channel may be programmed to act as a Wait signal for the 
CPU. In either mode, it is advisable to select and enable 
the mode in two separate accesses of the appropriate 
register. The first access should select the mode and the 
second access should enable the function. This proce- 
dure prevents glitches on the output pins. Reset forces 
Wait mode, with /W//REQ open-drain. 
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2.5.1.1 Wait On Transmit 

The Wait On Transmit function is selected by setting both 
D6 and D5 to and then enabling the function by setting 
D7 of WR1 to 1 . In this mode the /W//REQ pin carries the 



/WAIT signal, and is open-drain when inactive and Low 
when active. When the processor attempts to write to the 
transmit buffer when it is full, the SGC asserts /WAIT until 
the byte is written (Figure 2-21). 
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Figure 2-21 . Wait On Transmit Timing 



This allows the use of a block move instruction to transfer 
the transmit data. In the case of the Z80X30, /WAIT will go 
active in response to /DS going active, but only if WR8 is 
being accessed and a write is attempted. In all other 
cases, /WAIT remains open-drain. In the case of the 
Z85X30, /WAIT goes active in response to /WR going 
active, but only if the data buffer is being accessed, either 
directly or via the pointers. The /WAIT pin is released in 



response to the falling edge of PCLK. Details of the timing 
are shown in Figure 2-22. 

Care must be taken when using this function, particularly 
at slow transmission speed. The /WAIT pin stays active as 
long as the transmit buffer stays full, so there is a possibility 
that the CPU may be kept waiting for a long period. 
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Figure 2-22. Wait On Transmit Timing 
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2.5.1.2 Wait On Receive 

The Wait On Receive function is selected by setting D6 or 
WR1 to 0, D5 of WR1 to 1 , and then enabling the function 
by setting 07 of WR1 to 1. In this mode, the /W//REQ pin 
carries the /WAIT signal, and is open-drain when inactive 



IDS or/RD 
(from Rx FIFO) 



V 



and Low when active. When the processor attempts to 
read data from the Receive FIFO when it is empty, the SCO 
asserts /WAIT until a character has reached the exit 
location of the FIFO (Figure 2-23). 
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Figure 2-23. Wait On Receive Timing 



This allows the use of a block move instruction to transfer 
the receive data. In the case of the Z80X30, /WAIT goes 
active in response to IDS going active, but only if RR8 is 
being accessed and a read is attempted. In all other 
cases, /WAIT remains open-drain. In the case of the 
Z85X30, /WAIT goes active in response to /RD going 
active, but only if the receive data FIFO is being accessed, 
either directly or via the pointers. The /WAIT pin is released 



in response to the falling edge of PCLK. Details of the 
timing are shown in Figure 2-24. 

Care must be taken when this mode is used. The /WAIT pin 
stays active as long as the Receive FIFO remains empty. 
When the CPU access the SCC, the CPU remains in the 
wait state until data gets into the Receive FIFO, freezing the 
system. 
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Figure 2-24. Wait On Receive Timing 
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2.5.2 DMA Requests 



The two DMA request pins /W//REQ and /DTR//REQ can be 
programmed for DMA requests. The /W//REQ pin is used 
as either a transmit or a receive request, and the /DTR//REQ 
pin can be used as a transmit request only. For full-duplex 
operation, the 7W//REQ is used for receive, and the 
/DTR//REQ is used for transmit. These modes are de- 
scribed below. 



2.5.2.2 DMA Request On Transmit (using /W//REQ) 
The Request On Transmit function is selected by setting 
D6 of WR1 to 1, D5 of WR1 to 0, and then enabling the 
function by setting D7 of WR1 to 1 . In this mode, the /W// 
REQ pin carries the /REQ signal, which is active Low. When 
this mode is selected but not yet enabled, the /W//REQ is 
driven High. 



2.5.2.1 DMA Request on ESCC 

Transmit DMA request is also affected by WR7' bit D5. As 
noted earlier, WR7' D5 affects both the transmit interrupt 
and DMA request generation similarly. 

Note: WR7' D3 is ignored by the Receive Request function. 
This allows a DMA to transfer all bytes out of the Receive 
FIFO and still maintain the full advantage of the FIFO 
when the DMA has a long latency response acquiring the 
data bus. 

Bit D5 of WR7' is set to 1 after reset to maintain maximum 
compatibility with SCO designs. This is necessary be- 
cause if WR7' D5=0 when the request function is enabled, 
requests are made in rapid succession to fill the FIFO. 
Consequently, some designs which require an edge to be 
detected for each data transfer may not recover fast 
enough to detect the edges. This is handled by program- 
ming WR7' D5=1 , or changing the DMA to be level sensi- 
tive instead of edge sensitive. Programming WR7' D5=0 
has the advantage of the DMA requesting to keep the FIFO 
full. Therefore, if the CPU is busy, a significantly longer 
latency can be tolerated without the transmitter under- 
running. 



The /REQ pin generates a falling edge for each byte written 
to the transmit buffer when the DMA controller is to write 
new data. For the Z80X30, the /REQ pin then goes inactive 
on the falling edge of the DS that writes the new data (see 
AC spec #26, TdDSf(REQ)) For the Z85X30, the /REQ pin 
then goes inactive on the falling edge of the WR strobe that 
writes the new data (see AC spec #33, TdWRf(REQ)) This 
is shown in Figure 2-25. 

Note: The /REQ pin follows the state of the transmit buffer 
even though the transmitter is disabled. Thus, if the /REQ 
is enabled, the DMA writes data to the SCC before the 
transmitter is enabled. This will not cause a problem in 
Asynchronous mode, but it may cause problems in Syn- 
chronous mode because the SCC sends data in prefer- 
ence to flags or sync characters. It may also complicate 
the CRC initialization, which cannot be done until after the 
transmitter is enabled. 

On the ESCC, this complication can be avoided in SDLC 
mode by using the Automatic SDLC Opening Flag Trans- 
mission feature and the Auto EOM reset feature, which also 
resets the transmit CRC (see Section 4.4.1 for details). 
Applications using other synchronous modes should en- 
able the transmitter before enabling the /REQ function. 
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Figure 2-25. Transmit Request Assertion 
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With only one exception, the /REQ pin directly follows the 
state of the transmit buffer (for the ESCC as programmed 
by WR7' D5) in this mode. The SCC generates only one 
falling edge on /REQ per character requested and the 
timing for this is shown in Figure 2-26. 

The one exception occurs in synchronous modes at the 
end of a CRC transmission. At the end of a CRC transmis- 
sion, when the closing flag or sync character is loaded into 
the Transmit Shift Register, /REQ is pulsed High for one 



PCLK cycle. The DMA uses this falling edge on /REQ to 
write the first character of the next frame to the SCC. In the 
case of the Z80X30, /REQ goes High in response to the 
falling edge of DS, but only if the appropriate channel 
transmit buffer in the SCC is accessed. This is shown in 
Figure 2-25. In the case of the Z85X30, /REQ goes High in 
response to the falling edge of /WR, but only when the 
appropriate channel transmit buffer in the SCC is ac- 
cessed. This is shown in Figure 2-27. 
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Figure 2-26. Z80X30 Transmit Request Release 
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2.5.2.3 DMA Request On Transmit (using /DTR//REQ) 
A second Request on Transmit function is available on the 
/DTR//REQ pin. This mode is selected by setting D2 of 
WR14 to 1. /REQ goes Low when the Transmit FIFO is 
empty if WR7' D5=1, or when the exit location of the 
Transmit FIFO is empty if WR7' D5=0. In the Request 
mode, /REQ follows the state of the Transmit FIFO even 



though the transmitter is disabled. While D2 of WR1 4 is set 
to 0, the /DTR//REQ pin is /DTR and follows the inverted 
state of D7 in WR5. This pin is High after a channel or 
hardware reset and in the DTR mode. 

The /DTR//REQ pin goes inactive High between each 
transfer for a minimum of one PCLK cycle (Figure 28). 
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/WAIT//REQ 



/ 



Figure 2-28. /DTR//REQ Deassertion Timing 



ESCC: 

The timing of deactivation of this pin is programmabie 
through WR7' bitD4. The /DTR//REQ waits until the write 
operation has been completed before going inactive. 
Refer to Z85230AC spec #35a TdWRr(REQ) andZ80230 
AC spec #27a TdDSr(REQ). This mode is compatible with 
the SCC and guarantees that any subsequent access to 
the ESCC does not violate the valid access recovery time 
requirement 

If WR7' D4=1, the /DTR//REQ is deactivated with identical 
timing as the /W/REQ pin. Refer to Z85230 AC spec #35b 
TdWRr(REQ) and Z80230 AC spec #27b TdDSr(REQ). 



This feature is beneficial to applications needing the DMA 
request to be deasserted quickly. It prevents a full Trans- 
mit FIFO from being overwritten due to the assertion of 
REQUEST being too long and being recognized as a 
request for more data. 

Note: If WR7' D4= 1, analysis should be done to verify that 
the ESCC is not repeatedly accessed in less than four 
PCLKs. However, since many DMAs require four clock 
cycles to transfer data, this typically is not a problem. 
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In the Request mode, /REQ will follow the state of the 
transmit buffer even though the transmitter is disabled. 
Thus, if /REQ is enabled before the transmitter is enabled, 
the DMA may write data to the SCC before the transmitter 
is enabled. This does not cause a problem in Asynchro- 
nous mode, but may cause problems in Synchronous 
modes because the SCC sends data in preference to flags 
or sync characters. It may also complicate the CRC initial- 
ization, which cannot be done until after the transmitter is 
enabled. On the ESCC, this complication can be avoided 
in SDLC mode by using the Automatic SDLC Opening Flag 
Transmission feature and Auto EOM reset feature which 
also resets the transmit CRC. (See section 4.4.1.2 for 
details). Applications using other synchronous modes 
should enable the transmitter before enabling the /REQ 
function. 

With only one exception, the /REQ pin directly follows the 
state of the Transmit FIFO (for ESCC, as programmed by 
WR7' D5) in this mode. The one exception occurs in 
synchronous modes at the end of a CRC transmission. At 
the end of a CRC transmission, when the closing flag or 
sync character is loaded into the Transmit Shift Register, 
/REQ is pulsed High for one PCLK cycle. The DMA uses 
this falling edge on /REQ to write the first character of the 
next frame to the SCC. 

2.5.2.4 DMA Request On Receive 

The Request On Receive function is selected by setting D6 
and D5 of WR1 to 1 and then enabling the function by 



setting D7 of WR1 to 1. In this mode, the /W//REQ pin 
carries the /REQ signal, which is active Low. When REQ on 
Receive is selected, but not yet enabled (WR1 D7=0), the 
/W//REQ pin is driven High. When the enable bit is set, 
/REQ goes Low if the Receive FIFO contains a character at 
the time, or will remain High until a character enters the 
Receive FIFO. Note that the /REQ pin follows the state of 
the Receive FIFO even though the receiver is disabled. 
Thus, if the receiver is disabled and /REQ is still enabled, 
the DMA transfers the previously received data correctly. 
In this mode, the /REQ pin directly follows the state of the 
Receive FIFO with only one exception. /REQ goes Low 
when a character enters the Receive FIFO and remains 
Low until this character is removed from the Receive FIFO. 

The SCC generates only one falling edge on /REQ per 
character transfer requested (Figure 2-29). The one ex- 
ception occurs in the case of a special receive condition in 
the Receive Interrupt on First Character or Special Condi- 
tion mode, or the Receive Interrupt on Special Condition 
Only mode. In these two interrupt modes, any receive 
character with a special receive condition is locked at the 
top of the FIFO until an Error Reset command is issued. 
This character in the Receive FIFO would ordinarily cause 
additional DMA Requests after the first time it is read. 
However, the logic in the SCC guarantees only one falling 
edge on /REQ by holding /REQ High from the time the 
character with the special receive condition is read, and 
the FIFO locked, until after the Error Reset command has 
been issued. 



Character Available 
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to FIFO 



W/REQ 
(=REQ) 




Figure 2-29. DMA Receive Request Assertion 
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Once the FIFO is locked, It allows the checking of the 
Receive Error FIFO (RR1) to find the cause of the error. 
Locking the data FIFO, therefore, stops the error status 
from popping out of the Receive Error FIFO. Also, since the 
DMA request becomes inactive, the interrupt (Special 
Condition) is serviced. 



In the case of the Z80X30, /REQ goes High in response to 
the falling edge of IDS, but only if the appropriate receive 
buffer in the SCC is accessed (Figure 2-30). In the case of 
the Z85X30, /REQ goes High in response to the falling 
edge of /RD, but only when the appropriate receive buffer 
in the SCC is accessed (Figure 2-31). 



Once the FIFO is unlocked by the Error Reset command, 
/REQ again follows the state of the receive buffer. 
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Figure 2-30. Z80X30 Receive Request Release 
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Figure 2-31. Z85X30 Receive Request Release 
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2.6 TEST FUNCTIONS 



The SCC contains two other features useful for diagnostic 
purposes, controlled by bits in WR14. They are Local 
Loopback and Auto Echo. 

2.6.1 Local Loopback 

Local Loopback is selected when WR14 bit D4 is set to 1 . 
In this mode, the output of the transmitter is internally 
connected to the input of the receiver. At the same time, the 
TxD pin remains connected to the transmitter. In this mode, 
the /DCD pin is ignored as a receive enable and the /CTS 
pin is ignored as a transmitter enable even if the Auto 
Enable mode has been selected. Note that the DPLL input 
is connected to the RxD pin, not to the input of the receiver. 
This precludes the use of the DPLL in Local Loopback. 
Local Loopback is shown schematically in Figure 2-32. 




/DCD » 



j RxD 
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Figure 2-32. Local Loopback 



2.6.2 Auto Echo 

Auto Echo is selected when bit D3 of WR14 is set to 1 . In 
this mode, theTxD pin is connected directly to the RxD pin, 
and the receiver input is connected to the RxD pin. In this 
mode, the /CTS pin is ignored as a transmitter enable and 
the output of the transmitter does not connect to anything. 
If both the Local Loopback and Auto Echo bits are set to 
1 , the Auto Echo mode is selected, but both the /CTS pin 
and /DCD pin are ignored as auto enables. This should 
not be considered a normal operating mode, however 
(Figure 2-33). 
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Figure 2-33. Auto Echo 
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USER'S MANUAL 



3.1 INTRODUCTION 

The serial channels of the SCC are supported by ancillary 
circuitry for generating clocks and performing data encod- 
ing and decoding. This chapter presents a description of 
these functional blocks. 

Note to ESCC/CMOS Users: The maximum input fre- 
quency to the DPLL has been specified as two times the 
PCLK frequency (Spec #16b TxRX(DPLL)). There are no 
changes to the baud rate generators from the NMOS to the 
CMOS/ESCC. 



Chapter 3 

SCC/ESCC ANCILLARY SUPPORT 
CIRCUITRY 



Note to SCC Users: The ancillary circuitry in the ESCC is 
the same as in the SCC with the following noted changes. 
The DPLL (Dual Phased-Locked Loop) output, when used 
as the transmit clock source, has been changed to be free 
of jitter. Consequently, as this only affects the use of the 
DPLL as the transmit clock source (it is typically used for 
the receive clock source), this has no effect on using the 
DPLL as the receive clock source. 



3.2 BAUD RATE GENERATOR 

The Baud Rate Generator (BRG) is essential for asynchro- 
nous communications. Each channel in the SCC contains 
a programmable baud rate generator. Each generator 
consists of two 8-bit, time-constant registers forming a 
1 6-bit time constant, a 1 6-bit down counter, and a flip-flop 
on the output so that it outputs a square wave. On start-up, 
the flip-flop on the output is set High, so that it starts in a 
known state, the value in the time-constant register is 



loaded into the counter, and the counter begins counting 
down. When a count of zero is reached, the output of the 
baud rate generator toggles, the value in the time-constant 
register is loaded into the counter, and the process starts 
over. The programmed time constant is read from RR12 
and RR13. A block diagram of the baud rate generator is 
shown in Figure 3-1 . 
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Figure 3-1 . Baud Rate Generator 
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The time-constant can be changed at any time, but the new 
value does not take effect until the next load of the counter 
(i.e., after zero count is reached). 

No attempt is made to synchronize the loading of a new 
time-constant with the clock used to drive the generator. 
When the time-constant is to be changed, the generator 
should be stopped first by writing WR14 D0=0. After 
loading the new time constant, the BRG can be started 
again. This ensures the loading of a correct time constant, 
but loading does not take place until zero count or a reset 
occurs. 

If neither the transmit clock nor the receive clock are 
programmed to come from the /TRxC pin, the output of the 
baud rate generator may be made available for external 
use on the /TRxC pin. 

Note: This feature is very useful for diagnostic purposes. 
By programming the output of the baud rate generator as 
output on the /TRxC pin, the BRG is source and time tested, 
and the programmed time constant verified. 



Write to WR14 




Clock Source 
Counter Clock 



The clock source for the baud rate generator is selected by 
bit D1 of WR1 4. When this bit is set to 0, the BRG uses the 
signal on the /RTxC pin as its clock, independent of 
whether the /RTxC pin is a simple input or part of the crystal 
oscillator circuit. When this bit is set to 1, the BRG is 
clocked by the PCLK. To avoid metastable problems in the 
counter, this bit should be changed only while the baud 
rate generator is disabled, since arbitrarily narrow pulses 
can be generated at the output of the multiplexer when it 
changes status. 

The BRG is enabled while bit DO of WR14 is set to 1. It is 
disabled while WR1 4 D0=0 and after a hardware reset (but 
not a software reset). To prevent metastable problems 
when the baud rate generator is first enabled, the enable 
bit is synchronized to the baud rate generator clock. This 
introduces an additional delay when the baud rate generator 
is first enabled (Figure 3-2). The baud rate generator is 
disabled immediately when bit DO of WR14 is set to 0, 
because the delay is only necessary on start-up. The baud 
rate generator is enabled and disabled on the fly, but this 
delay on start-up must be taken into consideration. 



Counter First Decremented 
(after hardware reset) 

Counter First Decremented 
(after previous disable) 



1 — End of Write to WR14 with Enable 



Figure 3-2. Baud Rate Generator Start Up 
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The formulas relating the baud rate to the time-constant 
and vice versa are shown below. 



Time Constant = 



Clock Frequency 



-2 



Baud Rate = 



2 x (Clock Mode) x (Baud Rate) 
Clock Frequency 
2 x (Clock Mode) x (Time Constant + 2) 



In these formulas, the BRG clock frequency (PCLK or 
/RTxC) is in Hertz, the desired baud rate in bits/sec, Clock 
Mode is 1 in sync modes, 1 , 1 6, 32 or 64 in async mode and 
the time constant is dimensionless. The example in Table 
3-1 assumes a 2.4576 MHz clock (from /RTxC) factor of 1 6 
and shows the time constant for a number of popular baud 
rates. 



Other commonly used clock frequencies include 3.6846, 
4.6080, 4.91520, 6.144, 7.3728, 9.216, 9.8304, 12.288, 
14.7456, 19.6608 (units in MHz). 

Initializing the BRG is done in three steps. First, the time- 
constant is determined and loaded into WR12 and WR13. 
Next, the processor must select the clock source for the 
BRG by setting bit D1 of WR14. Finally, the BRG is enabled 
by setting bit DO ofWR14to1. 

Note: The first write to WR14 is not necessary after a 
hardware reset if the clock source is the /RTxC pin. This is 
because a hardware reset automatically selects the /RTxC 
pin as the BRG clock source. 



For example: 

TC = 



6 



2.4576 X10 
(2 X 16) x 150 



-2 =510 



Table 3-1. Baud Rates for 2.4576 MHz Clock and 16x 
Clock Factor 



Baud 


Time Constant 


Rate 


Decimal 


Hex 


38400 





0000 


19200 


2 


0002 


9600 


6 


0006 


4800 


14 


000E 


2400 


30 


001 E 


1200 


62 


003E 


600 


126 


007E 


300 


254 


00FE 


150 


510 


01 FE 
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3.3 DATA ENCODING/DECODING 



Data encoding is utilized to allow the transmission of clock 
and data information over the same medium. This saves 
the need to transmit clock and data over separate medium 
as would normally be required for synchronous data. The 
SCC provides four different data encoding methods, se- 



lected by bits D6 and D5 in WR1 0. An example of these four 
encoding methods is shown in Figure 3-3. Any encoding 
method is used in any X1 mode in the SCC, asynchronous 
or synchronous.The data encoding selected is active even 
though the transmitter or receiver is idling or disabled. 
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Figure 3-3. Data Encoding Methods 
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NRZ (Non-Return to Zero). In NRZ, encoding a 1 is repre- 
sented by a High level and a is represented by a Low 
level. In this encoding method, only a minimal amount of 
clocking information is available in the data stream in the 
form of transitions on bit-cell boundaries. In an arbitrary 
data pattern, this may not be sufficient to generate a clock 
for the data from the data itself. 

NRZI (Non-Return to Zero Inverted). In NRZI, encoding a 
1 is represented by no change in the level and a is 
represented by a change in the level. As in NRZ, only a 
minimal amount of clocking information is available in the 
data stream, in the form of transitions on bit cell bound- 
aries. In an arbitrary data pattern this may not be sufficient 
to generate a clock for the data from the data itself. In the 
case of SDLC, where the number of consecutive 1s in the 
data stream is limited, a minimum number of transitions to 
generate a clock are guaranteed. 

ESCC: 

TxD Pin Forced High in SDLC feature. When the ESCC is 
programmed for SDLC mode with NRZI data encoding 
and mark idle (WR10 D6=0, D5=1, D3=1), the TxD pin is 
automatically forced high when the transmitter goes to the 
mark idle state. There are several different ways for the 
transmitter to go into the idle state. In each of the following 
cases the TxD pin is forced high when the mark idle 
condition is reached: data, CRC, flag and idle; data, flag 
and idle; data, abort (on underrun) and idle; data, abort 
(command) and idle; idle flag and command to idle mark. 
The Force High feature is disabled when the mark idle bit 
is reset. The TxD pin is forced High on the falling edge of 
the TxC cycle after the falling edge of the last bit of the 
closing flag. Using SDLC Loop mode is independent of 
this feature. 

This feature is used in combination with the automatic 
SDLC opening flag transmission feature, WR7' D0= 1, to 
assure that data packets are properly formatted. There- 
fore, when these features are used together, it is not 
necessary for the CPU to issue any commands when using 



the force idle mode in combination with NRZI data encod- 
ing. If WR7' DO is reset, like the SCC, it is necessary to reset 
the mark idle bit (WR10 D2) to enable flag transmission 
before an SDLC packet is transmitted. 

FM1 (Biphase Mark). In FM1 encoding, also known as 
biphase mark, a transition is present on every bit cell 
boundary, and an additional transition may be present in 
the middle of the bit cell. In FM1 , a is sent as no transition 
in the center of the bit cell and a 1 is sent as a transition in 
the center of the bit cell. FM1 encoded data contains 
sufficient information to recover a clock from the data. 

FMO (Biphase Space). In FMO encoding, also known as 
biphase space, a transition is present on every bit cell 
boundary and an additional transition may be present in 
the middle of the bit cell. In FMO, a 1 is sent as no transition 
in the center of the bit cell and a is sent as a transition in 
the center of the bit cell. FMO encoded data contains 
sufficient information to recover a clock from the data. 

Manchester (Biphase Level). Manchester (biphase level) 
encoding always produces a transition at the center of the 
bit cell. If the transition is Low to High, the bit is 0. If the 
transition is High to Low, the bit is 1 . Encoding of Manchester 
format requires an external circuit consisting of a 'D' flip- 
flop and four gates (Figure 3-4). The SCC is used to 
decode Manchester data by using the DPLL in the FM 
mode and programming the receiver for NRZ data (See 
Section 3.1.3) 

Data Encoding Initialization. The data encoding method is 
selected in the initialization procedure before the transmitter 
and receiver are enabled, but no other restrictions apply. 
Note that in NRZ and NRZI, the receiver samples the data 
only on one edge, as shown in Figure 3-3. However, in FM1 
and FMO, the receiver samples the data on both edges. 
Also, as shown in Figure 3-3, the transmitter defines bit cell 
boundaries by one edge in all cases and uses the other 
edge in FM1 and FMO to create the mid-bit transition. 
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Figure 3-4. Manchester Encoding Circuit 
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3.4 DPLL DIGITAL PHASE-LOCKED LOOP 



Each channel of the SCC contains a digital phase-locked 
loop that can be used to recover clock information from a 
data stream with NRZI, FM, NRZ, or Manchester encoding. 
The DPLL is driven by a clock nominally at 32 (NRZI) or 1 6 
(FM) times the data rate. The DPLL uses this clock, along 
with the data stream, to construct a receive clock for the 
data. This clock can then be used as the SCC receive 
clock, the transmit clock, or both. 



Figure 3-5 shows a block diagram of the digital phase- 
locked loop. It consists of a 5-bit counter, an edge detector, 
and a pair of output decoders. The clock for the DPLL 
comes from the output of a two-input multiplexer, and the 
two outputs go to the transmitter and receive clock multi- 
plexers. The DPLL is controlled by seven commands 
encoded in WR14 bits D7, D6 and D5. 



RxD. 



Edge Detector 



Count Modifier r 


. ) 




5-Bit ( 


'■ 1 

Counter 1 



v f ▼ t v 



Decode 



Decode 



. Receive 
Clock 



. Transmit 
Clock 



Figure 3-5. Digital Phase-Locked Loop 



The clock source for the DPLL is selected issuing one of 
the two commands in WR14, that is: 

WR14 (7-5) = 100 selects the BRG 
WR14 (7-5) = 101 selects the /RTxC pin 

The first command selects the baud rate generator as the 
clock source. The other command selects the /RTxC pin as 
the clock source, independent of whether the /RTxC pin is 
a simple input or part of the crystal oscillator circuit. 

Initialization of the DPLL is done at any time during the 
initialization sequence, but should be done after the clock 
modes have been selected in WR11, and before the 
receiver and transmitter are enabled. When initializing the 
DPLL, the clock source should be selected first, followed 
by the selection of the operating mode. 

To avoid metastable problems in the counter, the clock 
source selection is made only while DPLL is disabled, 
since arbitrarily narrow pulses are generated at the output 
of the multiplexer when it changes status. 

The DPLL is programmed to operate in one of two modes, 
as selected by commands in WR14. 

WR14 (7-5) = 111 selects NRZI mode 
WR14 (7-5) = 110 selects FM mode 

Note: A channel or hardware reset disables the DPLL, 
selects the /RTxC pin as the clock source for the DPLL, and 
places it in the NRZI mode. 



As in the case of the clock source selection, the mode of 
operation is only changed while the DPLL is disabled to 
prevent unpredictable results. 

In the NRZI mode, the DPLL clock must be 32 times the 
data rate. In this mode, the transmit and receive clock 
outputs of the DPLL are identical, and the clocks are 
phased so that the receiver samples the data in the middle 
of the bit cell. In NRZI mode, the DPLL does not require a 
transition in every bit cell, so this mode is useful for 
recovering the clocking information from NRZ and NRZI 
data streams. 

In the FM mode, the DPLL clock must be 1 6 times the data 
rate. In this mode, the transmit clock output of the DPLL 
lags the receive clock outputs by 90 degrees to make the 
transmit and receive bit cell boundaries the same, be- 
cause the receiver must sample FM data at one-quarter 
and three-quarters bit time. 

The DPLL is enabled by issuing the Enter Search Mode 
command in WR14; that is WR14 (7-5) = 001. The Enter 
Search Mode command unlocks the counter, which is held 
while the DPLL is disabled, and enables the edge detec- 
tor. If the DPLL is already enabled when this command is 
issued, the DPLL also enters Search Mode. 
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Enter Search Mode is also used to reset the DPLL to a 
known state if it is suspected that synchronization has 
been lost. Note that the DPLL and the receiver are inde- 
pendent, so whether the receiver is disabled or not en- 
abled, DPLL samples whatever is on the RxD line. 

In the FM mode the DPLL requires a transition in every bit 
cell, and if this transition is not present in two consecutively 
sampled bit cells, the DPLL automatically enters search 
mode and the DPLL does not provide any clock output. 



In Search mode, the counter is held at a specific count and 
no outputs are provided. The DPLL remains in this status 
until an edge is detected in the receive data stream. This 
first edge is assumed to occur on a bit cell boundary, and 
the DPLL begins providing an output to the receiver that 
properly samples the data. From this point on, the DPLL 
adjusts its output to remain in phase with the receive data. 
If the first edge that the DPLL sees does not occur on a bit 
cell boundary, the DPLL will eventually lock on to the 
receive data, but it takes longer to do. 



3.4.1 DPLL Operation in the NRZI Mode 

To operate in NRZI mode, the DPLL must be supplied with 
a clock that is 32 times the data rate. The DPLL uses this 
clock, along with the receive data, to construct receive and 
transmit clock outputs that are phased to properly receive 
and transmit data. 



sampling the data too early in the bit cell. In response to 
this, the DPLL extends its count by one during the next 
to 31 counting cycle, which effectively moves the edge of 
the clock that samples the receive data closer to the center 
of the bit cell. 



To do this, the DPLL divides each bit cell into four regions, 
and makes an adjustment to the count cycle of the 5-bit 
counter dependent upon the region a transition on the 
receive data input occurred (Figure 3-6). 

Ordinarily, a bit-cell boundary occurs between count 15 
and count 16, and the DPLL output causes the data to be 
sampled in the middle of the bit cell. However, four differ- 
ent situations can occur: 

If the bit-cell boundary (from space to mark) occurs any- 
where during the second half of count 1 5 or the first half of 
count 16, the DPLL allows the transition without making a 
correction to its count cycle. 

If the bit cell boundary (from space to mark) occurs 
between the middle of count 1 6 and count 31 , the DPLL is 



If the transition occurs between count and the middle of 
count 15, the output of the DPLL is sampling the data too 
late in the bit cell. To correct this, the DPLL shortens its 
count by one during the next to 31 counting cycle, which 
effectively moves the edge of the clock that samples the 
receive data closer to the center of the bit cell. 

If the DPLL does not see any transition during a counting 
cycle, no adjustment is made in the following counting 
cycle. 

If an adjustment to the counting cycle is necessary, the 
DPLL modifies count 5, either deleting it or doubling it. 
Thus/only the Low time of the DPLL output is lengthened 
or shortened. 



Bit Cell 



Count |16|17|18|19|20|21 22|23*24|25 26^27 |28 |29 |30 [31 |0 1 | 2 | 3 | 4 | 5 | 6 ]T 8 | 9 |10 |11 |12 |13|14 |15| 



Correction 



DPLL Out 



Add One Count 



Subtract One Count 



I] 



f No Change 



No Change 



Figure 3-6. DPLL in NRZI Mode 
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While the DPLL is in search mode, the counter remains at cessed in RR10, are not used in NRZI mode. An example 
count 16, where the DPLL outputs are both High. The of the DPLL in operation is shown in Figure 3-7. 
missing clock latches in the DPLL, which may be ac- 
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1 r 



DPLL 
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c SwS 1+11-1 1+11-1 i +1 1 -1 1 +1 1 -1 1 +1 1 -1 1 +1 1 -1 1 +1 1 -1 1 +1 1 -mn 

Length 32 | 32 | 32 | 31 | 31 | 31 | 33 | 33 | 33 | 
Figure 3-7. DPLL Operating Example (NRZI Mode) 



3.4.2 DPLL Operation in the FM Modes 

To operate in FM mode, the DPLL must be supplied with a 
clock that is 16 times the data rate. The DPLL uses this 
clock, along with the receive data, to construct, receive, 
and transmit clock outputs that are phased to receive and 
transmit data properly. 



In FM mode, the counter in the DPLL counts from to 31 , 
but now each cycle corresponds to 2-bit cells. To make 
adjustments to remain in phase with the receive data, the 
DPLL divides a pair of bit cells into five regions, making the 
adjustment to the counter dependent upon which region 
the transition on the receive data input occurred 
(Figure 3-8). 



Bit Cell 



Count fie" 17|18|19 20|21 22 23 124 25 26 27 28 29 30 31 01 23456789 10 11 |12 13 14 15~) 



Correction 1 1 +1 J* 



Ignored 



V 



I No Change 
RX DPLL Out [" 



No Change 



TX DPLL Out L 



Figure 3-8. DPLL Operation in the FM Mode 
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In FM mode, the transmit clock and receive clock outputs 
from the DPLL are not in phase. This is necessary to make 
the transmit and receive bit cell boundaries coincide, 
since the receive clock must sample the data one-fourth 
and three-fourths of the way through the bit cell. 

Ordinarily, a bit cell boundary occurs between count 1 5 or 
count 16, and the DPLL receive output causes the data to 
be sampled at one-fourth and three-fourths of the way 
through the bit cell. 

However, four variations can occur: 

If the bit-cell boundary (from space to mark) occurs any- 
where during the second half of count 15 or the first half of 
count 16, the DPLL allows the transition without making a 
correction to its count cycle. 

If the bit-cell boundary (from space to mark) occurs be- 
tween the middle of count 1 6 and the middle of count 1 9, 
the DPLL is sampling the data too early in the bit cell. In 
response to this, the DPLL extends its count by one during 
the next to 31 counting cycle, which effectively moves the 
receive clock edges closer to where they should be. 

Any transitions occurring between the middle of count 19 
in one cycle and the middle of count 12 during the next 
cycle are ignored by the DPLL. This guarantees that any 
data transitions in the bit cells do not cause an adjustment 
to the counting cycle. 

If no transition occurs between the middle of count 1 2 and 
the middle of count 19, the DPLL is probably not locked 
onto the data properly. When the DPLL misses an edge, 
the One Clock Missing bit is RR10, it is set to 1 and latched. 
It will hold this value until a Reset Missing Clock command 
is issued in WR14, or until the DPLL is disabled or pro- 
grammed to enter the Search mode. Upon missing this one 
edge, the DPLL takes no other action and does not modify 
its count during the next counting cycle. 

If the DPLL does not see an edge between the middle of 
count 1 2 and the middle of count 1 9 in two successive to 
31 count cycles, a line error condition is assumed. If this 



occurs, the Two Clocks Missing bit in RR10 is set to 1 and 
latched. At the same time, the DPLL enters the Search 
mode. The DPLL makes the decision to enter the Search 
mode during count 2, where both the receive clock and 
transmit clock outputs are Low. This prevents any glitches 
on the clock outputs when the Search mode is entered. 
While in the Search mode, no clock outputs are provided 
by the DPLL. The Two Clocks Missing bit in RR 1 is latched 
until a Reset Missing Clock command is issued in WR14, 
or until the DPLL is disabled or programmed to enter the 
Search mode. 

While the DPLL is disabled, the transmit clock output of the 
DPLL may be toggled by alternately selecting FM 
and NRZI mode in the DPLL. The same is true of the 
receive clock. 

While the DPLL is in the Search mode, the counter remains 
at count 16 where the receive output is Low and the 
transmit output is Low. This fact is used to provide a 
transmit clock under software control since the DPLL is in 
the Search mode while it is disabled. 

As in NRZI mode, if an adjustment to the counting cycle is 
necessary, the DPLL modifies count 5, either deleting it or 
doubling it. If no adjustment is necessary, the count 
sequence proceeds normally. 

When the DPLL is programmed to enter Search mode, only 
clock transitions should exist on the receive data pin. If this 
is not the case, the DPLL may attempt to lock on to the data 
transitions. If the DPLL does lock on to the data transitions, 
then the Missing Clock condition will inevitably occur 
because data transitions are not guaranteed every bit cell. 

To lock in the DPLL properly, FMO encoding requires 
continuous 1s received when leaving the Search mode. In 
FM1 encoding, continuous Os are required; with Manches- 
ter encoded data this means alternating 1 s and Os. With all 
three of these data encoding methods there is always at 
least one transition in every bit cell, and in FM mode the 
DPLL is designed to expect this transition. 
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3.4.3 DPLL Operation in the Manchester Mode 



The SCC can be used to decode Manchester data by 
using the DPLL in the FM mode and programming the 
receiver for NRZ data. Manchester encoded data contains 
a transition at the center of every bit cell; it is the direction 
of this transition that distinguishes a 1 from a 0. Hence, for 
Manchester data, the DPLL should be in FM mode (WR14 
command D7=1 , D6=1 , D5=0), but the receiver should be 
set up to accept NRZ data (WR10 D6=0, D5=0). 

3.4.4 Transmit Clock Counter (ESCC only) 

The ESCC includes a Transmit Clock Counter which par- 
allels the DPLL. This counter provides a jitter-free clock 
source to the transmitter by dividing the DPLL clock source 
by the appropriate value for the programmed data encoding 



format as shown in Figure 3-9. Therefore, in FM mode (FMO 
or FM1 ), the counter output is the input frequency divided 
by 16. In NRZI mode, the counter frequency is the input 
divided by 32. The counter output replaces the DPLL 
transmit clock output, available as the transmit clock 
source. This has no effect on the use of the DPLL as the 
receive clock source. 

The output of the transmit clock derived from this counter 
is available to the /TRxC pin when the DPLL output is 
selected as the transmit clock source. Care must be taken 
using ESCC in SDLC Loop mode with the DPLL. The SDLC 
Loop mode requires sychronizedTx and Rx clocks, but the 
ESCC's DPLL might be off-sync because of this Transmit 
Clock Counter. 



DPL \nput 1 H DPLL | ► DPLL Output to Receiver 



-> | DPLL Counter | ► DPLL Output to Transmitter 

Input Divided by 1 6 (FMO or FM1 ) 
Input Divided by 32 for NRZI 



Figure 3-9. DPLL Transmit Clock Counter Output (ESCC only) 
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3.5 CLOCK SELECTION 



The SCC can select several clock sources for internal and 
external use. Write Register 1 1 is the Clock Mode Control 
register for both the receive and transmit clocks. It deter- 
mines the type of signal on the /SYNC and /RTxC pins and 
the direction of the /TRxC pin. 

The SCC is programmed to select one of several sources 
to provide the transmit and receive clocks. 

The source of the receive clock is controlled by bits D6 and 
D5 of WR11. The receive clock may be programmed to 
come from the /RTxC pin, the /TRxC pin, the output of the 
baud rate generator, or the receive output of the DPLL. 

The source of the transmit clock is controlled by bits D4 
and D3 of WR1 1 . The transmit clock may be programmed 
to come from the /RTxC pin, the /TRxC pin, the output of the 
baud rate generator, or the transmit output of the DPLL. 

Ordinarily, the /TRxC pin is an input, but it can become an 
output if this pin has not been selected as the source for the 
transmitter or the receiver, and bit D2 of WR1 1 is set to 1 . 
The selection of the signal provided on the /TRxC output 
pin is controlled by bits D1 and DO of WR1 1 . The /TRxC pin 
is programmed to provide the output of the crystal oscil- 
lator, the output of the baud rate generator, the receive 
output of the DPLL or the actual transmit clock. If the output 
of the crystal oscillator is selected, but the crystal oscillator 
has not been enabled, the /TRxC pin is driven High. The 
option of placing the transmit clock signal on the /TRxC pin 
when it is an output allows access to the transmit output of 
the DPLL. 

Figure 3-10 shows a simplified schematic diagram of the 
circuitry used in the clock multiplexing. It shows the inputs 
to the multiplexer section, as well as the various signal 
inversions that occur in the paths to the outputs. 

Selection of the clocking options may be done anywhere 
in the initialization sequence, but the final values must be 



selected before the receiver, transmitter, baud rate gen- 
erator, or DPLL are enabled to prevent problems from 
arbitrarily narrow clock signals out of the multiplexers. The 
same is true of the crystal oscillator, in that the output 
should be allowed to stabilize before it is used as a clock 
source. 

Also shown are the edges used by the receiver, transmitter, 
baud rate generator and DPLL to sample or send data or 
otherwise change state. For example, the receiver samples 
data on the falling edge, but since there is an inversion in 
the clock path between the /RTxC pin and the receiver, a 
rising edge of the /RTxC pin samples the data for the 
receiver. 

The following shows three examples for selecting different 
clocking options. Figure 3-1 1 shows the clock set up for 
asynchronous transmission, 1 6x clock mode using the on- 
chip oscillator with an external crystal. This example uses 
the oscillator as the input to the baud rate generator, 
although it can be used directly as the transmit or receive 
clock source. The registers involved are WR1 1 thru WR14 
and the figure shows the programming in these registers. 

An example of asynchronous communication where a 1x 
clock is obtained from an external MODEM is shown in 
Figure 3-12. The data encoding is NRZ. Note that: 

1 . The BRG is not used under this configuration. 

2. The x1 mode in Asynchronous mode is a combination of 
both synchronous and asynchronous transmission. The 
data is clocked by a common timing base, but characters 
are still framed with Start and Stop bits. Because the 
receiver waits for one clock period after detecting the first 
High-to-Lowtransition before beginning to assemble char- 
acters, the data and clock is synchronized externally. The 
x1 mode is the only mode in which a data encoding method 
other than NRZ is used. 
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Figure 3-10. Clock Multiplexer 
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Figure 3-11. Async Clock Setup Using an External Crystal 
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Figure 3-12. Clock Source Selection 



Figure 3-13 shows the use oftheDPLLto derive a 1x clock The DPLL clock output = RxC (receiver clock) WR1 1 . 
from the data. In this example: 

SetFMmodeWR14. 

The DPLL clock input = BRG output (x16 the data rate) 

WR14. Set FM mode WR10. 
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Figure 3-13. Synchronous Transmission, 1x Clock Rate, FM Data Encoding, using DPLL 
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3.6 CRYSTAL OSCILLATOR 



Each channel contains a high gain oscillator amplifier for 
use with an external crystal circuit. The amplifier is avail- 
able between the /RTxC pin (crystal input) and the /SYNC 
pin (crystal output) for each channel. 

The oscillator amplifier is enabled by writing WR1 1 D7=1 . 
While the crystal oscillator is enabled, anything that has 
selected the /RTxC pin as its clock source automatically 
connects to the output of the crystal oscillator. 

Note: The output of the oscillator amplifier can be pro- 
grammed to output on the ATRxC pin, which is particularly 
valuable for diagnostic purposes. Because amplifier char- 
acteristics can be affected by the impedance of measure- 
ment equipment applied directly to the crystal circuit, 
using the /TRxC pin allows the oscillation to be tested 
without affecting the circuit. 



Of course, since the oscillator uses the /RTxC and /SYNC 
pins, this precludes the use of these pins for other functions. 
In synchronous modes, no sync pulse is output, and the 
External Sync mode cannot be selected. In asynchronous 
modes, the state of the Sync/Hunt bit in RRO is no longer 
controlled by the /SYNC pin. Instead, the Sync/Hunt bit is 
forced to 0. 

The crystal oscillator requires some finite time to stabilize 
and must be allowed to stabilize before it is used as a clock 
source. This stabilization time is dependent on the external 
circuit impedance and 20 ms is a suggested minimum. 
The External Crystal should operate in parallel resonance. 
For further details on designing with the crystal, refer to 
Appendix A, "On-Chip Oscillator Design". 
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User's Manual 



4.1 INTRODUCTION 

The SCC provides two independent, full-duplex channels 
programmable for use in any common asynchronous or 
synchronous data communication protocol. The data 
communication protocols handled by the SCC are: 

■ Asynchronous mode: 

Asynchronous (x16, x32, or x64 clock) 
Isochronous (xl clock) 

■ Character-oriented mode: 

Monosynchronous 
Bisynchronous 
External Synchronous 

■ Bit-Oriented mode: 

SDLC/HDLC 
SDLC/HDLC Loop 



Chapter 4 

Data communication modes 



4.1.1 Transmit Data Path Description 

A diagram of the transmit data path is shown in Figure 4-1 . 
The transmitter has a Transmit Data buffer (a 4-byte deep 
FIFO on the ESCC, a one byte deep buffer on the NMOS/ 
CMOS version) which is addressed through WR8. It is not 
necessary to enable the transmit buffer. It is available in all 
modes of operation. The Transmit Shift register is loaded 
from either WR6, WR7, or the Transmit Data buffer. In 
Synchronous modes, WR6 and WR7 are programmed with 
the sync characters. In Monosync mode, an 8-bit or 6-bit 
sync character is used (WR6), whereas a 16-bit sync 
character is used in the Bisynchronous mode (WR6 and 
WR7). In bit-oriented Synchronous modes, the SDLC flag 
character (7E hex) is programmed in WR7 and is loaded 
into the Transmit Shift Register at the beginning and end of 
each message. 
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Figure 4-1. Transmit Data Path 
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For asynchronous data, the Transmit Shift register is for- 
matted with start and stop bits along with the data; option- 
ally with parity information bit. The formatted character is 
shifted out to the transmit multiplexer at the selected clock 
rate. WR6 & WR7 are not used in Asynchronous mode. 

Synchronous data (except SDLC/HDLC) is shifted to the 
CRC generator as well as to the transmit multiplexer. 
SDLC/HDLC data is shifted to the CRC Generator and out 
through the zero insertion logic (which is disabled while the 
flags are being sent). A is inserted in all address, control, 
information, and frame checkfields following five contiguous 
1s in the data stream. The result of the CRC generator for 
SDLC data is also routed through the zero insertion logic 
and then to the transmit multiplexer. 



4.1.2 Receive Data Path Description 

On the ESCC, the receiver has an 8-byte deep, 8-bit wide 
Data FIFO, while the NMOS/CMOS version receiver has a 
3-byte deep, 8-bit wide data buffer. In both cases, the Data 
buffer is paired with an 8-bit Error FIFO and an 8-bit Shift 
Register. The receive data path is shown in Figure 4-2. This 
arrangement creates a 8-character buffer, allowing time 
for the CPU to service an interrupt or for the DMA to acquire 
the bus at the beginning of a block of high-speed data. It 
is not necessary to enable the Receive FIFO, since it is 
available in all modes of operation. For each data byte in 
the Receive FIFO, a byte is loaded into the Error FIFO to 
store parity, framing, and other status information. The 
Error FIFO is addressed thru Read Register 1 . 
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Figure 4-2. Receive Data Path 
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Incoming data is routed through one of several paths 
depending on the mode and character length. In Asyn- 
chronous mode, serial data enters the 3-bit delay if a 
character length of seven or eight bits is selected. If a 
character length of five or six bits is selected, data enters 
the receive shift register directly. 

In Synchronous modes, the data path is determined by the 
phase of the receive process currently in operation. A 
synchronous receive operation begins with a hunt phase 
in which a bit pattern that matches the programmed sync 
characters (6-,8-, or 1 6-bit) is searched. 

The incoming data then passes through the Sync register 
and is compared to a sync character stored in WR6 or WR7 
(depending on which mode it is in). The Monosync mode 
matches the sync character programmed in WR7 and the 
character assembled in the Receive Sync register to 
establish synchronization. 

Synchronization is achieved differently in the Bisync mode. 
Incoming data is shifted to the Receive Shift register while 
the next eight bits of the message are assembled in the 
Receive Sync register. If these two characters match the 
programmed characters in WR6 and WR7, synchroniza- 
tion is established. Incoming data can then bypass the 
Receive Sync register and enter the 3-bit delay directly. 

The SDLC mode of operation uses the Receive Sync 
register to monitor the receive data stream and to perform 
zero deletion when necessary; i.e., when five continuous 
1 s are received, the sixth bit is inspected and deleted from 
the data stream if it is 0. The seventh bit is inspected only 
if the sixth bit equals one. If the seventh bit is 0, a flag 
sequence has been received and the receiver is synchro- 



nized to that flag. If the seventh bit is a 1 , an abort or an EOP 
(End Of Poll) is recognized, depending upon the selection 
of either the normal SDLC mode or SDLC 
Loop mode. 

Note: The insertion and deletion of the zero in the SDLC 
data stream is transparent to the user, as it is done after the 
data is written to the Transmit FIFO and before data is read 
from the Receive FIFO. This feature of the SDLC/HDLC 
protocol is to prevent the inadvertent sending of an ABORT 
sequence as part of the data stream. It is also valuable to 
applications using encoded data to insure a sufficient 
number of edges on the line to keep a DPLL synchronized 
on a receive data stream. 

The same path is taken by incoming data for both SDLC 
and SDLC Loop modes. The reformatted data enters the 
3-bit delay and is transferred to the Receive Shift register. 
The SDLC receive operation begins in the hunt phase by 
attempting to match the assembled character in the Receive 
Shift Register with the flag pattern in WR7. When the flag 
character is recognized, subsequent data is routed through 
the same path, regardless of character length. 

Either the CRC-1 6 or CRC-SDLC (cyclic redundancy check 
or CRC) polynomial can be used for both Monosync and 
Bisync modes, but only the CRC-SDLC polynomial is used 
for SDLC operation. The data path taken for each mode is 
also different. Bisync protocol is a byte-oriented operation 
that requires the CPU to decide whether or not a data 
character is to be included in CRC calculation. An 8-bit 
delay in all Synchronous modes except SDLC is allowed 
for this process. In SDLC mode, all bytes are included in 
the CRC calculation. 



4.2 ASYNCHRONOUS MODE 

In asynchronous communications, data is transferred in 
the format shown in Figure 4-3. 




Figure 4-3. Asynchronous Message Format 
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The transmission of a character begins when the line 
makes a transition from the 1 state (or MARK condition) to 
the state (or SPACE condition). This transition is the 
reference by which the character's bit cell boundaries are 
defined. Though the transmitter and receiver have no 
common clock signal, they must be at the same data rate 
so that the receiver can sample the data in the center of the 
bit cell. 

The SCC also supports Isochronous mode, which is the 
same as Asynchronous except that the clock is the same 
rate as the data. This mode is selected by selecting 
x1 clock mode in WR4 (D7 & D6=0). Using this mode 
typically requires that the transmit clock source be trans- 
mitted along with the data, or that the clock be synchro- 
nized with the data. 

The character can be broken up into four fields: 

■ Start bit - signals the beginning of a character frame. 

■ Data field - typically 5-8 bits wide. 

■ Parity bit - optional error checking mechanism. 

■ Stop bit(s) - Provides a minimum interval between the 
end of one character and the beginning of the next. 

Generation and checking of parity is optional and is 
controlled by WR4 D1 & DO. WR4 bit DO is used to enable 
parity. If WR4 bit D1 is set, even parity is selected and if D1 
is reset, odd parity is selected. For even parity, the parity 
bit is set/reset so that the data byte plus the parity bit 
contains an even number of 1s. For odd parity, the parity 
bit is set/reset such that the data byte plus the parity bit 
contains an odd number of 1s. 

The SCC supports Asynchronous mode with a number of 
programmable options including the number of bits per 
character, the number of stop bits, the clock factor, mo- 
dem interface signals, and break detect and generation. 

Asynchronous mode is selected by programming the 
desired number of stop bits in D3 and D2of WR4. Program- 
ming these two bits with other than 00 places both the 
receiver and transmitter in Asynchronous mode. In this 
mode, the SCC ignores the state of bits D4, D3, and D2 of 
WR3, bits D5 and D4 of WR4, bits D2 and DO of WR5, all of 
WR6 and WR7, and all of WR1 except D6 and D5. Ignored 
bits are programmed with 1 or (Table 4-1). 



Table 4-1. Write Register Bits Ignored in 
Asynchronous Mode 



Register 


D7 


D6 


D5 


D4 


D3 


D2 


D1 


DO 


WR3 








X 


X 


X 







WR4 






X 


X 










WR5 












X 




X 


WR6 


X 


X 


X 


X 


X 


X 


X 


X 


WR7 


X 


X 


X 


X 


X 


X 


X 


X 


WR10 


X 






X 


X 


X 


X 


X 



Note: If WR3 D1 is set (enabling the sync character load 
inhibit feature), any character matching the value in WR6 
is stripped out of the incoming data stream and not put into 
the Receive FIFO. Therefore, as this feature is typically only 
desired in synchronous formats, this bit should reset in 
Asynchronous mode. 

4.2.1 Asynchronous Transmit 

Asynchronous mode is selected by specifying the number 
of stop bits per character in bits D3 and D2 of WR4. The 
three options available are one, one-and-a-half, and two 
stop bits per character. These two bits select only the 
number of stop bits for the transmitter, as the receiver 
always checks for one stop bit. 

The number of bits per transmitted character is controlled 
both by bits D6 and D5 in WR5 and the way the data is 
formatted within the transmit buffer (in the case of the 
ESCC, Transmit FIFO). The bits in WR5 allow the option of 
five, six, seven, or eight bits per character. In all cases the 
data must be right-justified, with the unused bits being 
ignored except in the case of five bits per character. When 
the five bits per character option is selected, the data may 
be formatted before being written to the transmit buffer. 
This allows transmission of from one to five bits per char- 
acter. The formatting is shown in Table 4-2. 
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Table 4-2. Transmit Bits per Character 



Bit 7 


Bit 6 










5 or less bits / character 





1 


7 bits / character 


1 





6 bits / character 


1 


1 


8 bits / character 



Note: 

For five or less bits per character selection in WR5, the following encoding 
is used in the data sent to the transmitter. D is the data bit(s) to be sent. 



D7 D6 


D5 


D4 D3 


D2 


D1 


DO 




1 


1 


1 


1 











D 


Sends one data bit 


1 


1 


1 











D 


D 


Sends two data bits 


1 


1 











D 


D 


D 


Sends three data bits 


1 











D 


D 


D 


D 


Sends four data bits 











D 


D 


D 


D 


D 


Sends five data bits 



An additional bit, carrying parity information, may be 
automatically appended to every transmitted character by 
setting bit DO of WR4 to 1 . This bit is sent in addition to the 
number of bits specified in WR4 or by bit D1 of WR4. If this 
bit is set to 1 , the transmitter sends even parity and, if set 
to 0, the parity is odd. 

The transmitter may be programmed to send a Break by 
setting bit D3 of WR5 to 1. The transmitter will send 
contiguous 0s from the first transmit clock edge after this 
command is issued, until the first transmit clock edge after 
this bit is reset. The transmit clock edges referred to here 
are those that defined transmitted bit cell boundaries. Care 
must be taken when Break is sent. As mentioned above, 
the SCC initiates the Break sequence regardless of the 
character boundaries. Typically, the break sequence is 
defined as "null character (all data) with framing error". 
The other party may not be able to recognize it as a break 
sequence if the Send Break bit has been set in the middle 
of sending a non-zero character. 

An additional status bit for use in Asynchronous mode is 
available in bit DO of RR1. This bit, called All Sent, is set 
when the transmitter is completely empty and any previous 
data or stop bits have reached the TxD pin. The All Sent bit 
can be used by the processor as an indication that the 
transmitter may be safely disabled, or indication to change 
the modem status signal. 

The SCC may be programmed to accept a transmit clock 
that is one, sixteen, thirty-two, or sixty-four times the data 
rate. This is selected by bits D7 and D6 in WR4, in common 
with the clock factor for the receiver. 



Note: When using Isosynchronous (X1 clock) mode, one- 
and-a-half stop bits are not allowed. Only one or two stop 
bits should be selected. If some length other than one stop 
bit is desired in the times one mode, only two stop bits may 
be used. Also, in this mode, the Transmitter usually needs 
to send clocking information (transmit clock) along with the 
data in order to receive data correctly. 

There are two modem control signals associated with the 
transmitter provided by the SCC; /RTS and /CTS. 

The /RTS pin is a simple output that carries the inverted 
state of the RTS bit (D1) in WR5, unless the Auto Enables 
mode bit (D5) is set in WR3. When Auto Enables is set, the 
/RTS pin immediately goes Low when the RTS bit is set. 
However, when the RTS bit is reset, the /RTS pin remains 
Low until the transmitter is completely empty and the last 
stop bit has left the TxD pin. Thus, the /RTS pin may be 
used to disable external drivers for the transmit data. The 
/CTS pin is ordinarily a simple input to the CTS bit in RRO. 
However, if Auto Enables mode is selected, this pin be- 
comes an enable for the transmitter. That is, if Auto Enables 
is on and the /CTS pin is High, the transmitter is disabled; 
the transmitter is enabled while the /CTS pin is Low. 

The initialization sequence for the transmitter in Asynchro- 
nous mode is WR4 first to select the mode, then WR3 and 
WR5 to select the various options. At this point the other 
registers should be initialized as necessary. When all of 
this is complete, the transmitter may be enabled by setting 
bit D3 of WR5 to 1 . Note that the transmitter and receiver 
may be initialized at the same time. 

4.2.1 .1 Asynchronous transmit on the NMOS/CMOS 

On the NMOS/CMOS version of the SCC, characters are 
loaded from the transmit buffer to the shift register where 
they are given a start bit and a parity bit (as programmed), 
and are shifted out to the TxD pin. The transmit buffer 
empty interrupt and the DMA request (either /W//REQ or 
/DTR//REQ pin) are asserted when the transmit buffer is 
empty, if these are enabled. At this time, the CPU or the 
DMA is able to write one byte of transmit data. The Transmit 
Buffer Empty (TBE) bit (RRO, bit D2) also follows the state 
of the transmit buffer. The All Sent bit, RR1 , bit DO, can be 
polled to determine when the last bit of transmit data has 
cleared the TxD pin. For details about the transmit DMA 
and transmit interrupts, refer to Section 2.4.8 "Transmit 
Interrupt and Transmit Buffer Empty bit." 
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4.2.1 .2 Asynchronous transmit on the ESCC 

On the ESCC, characters are loaded from the Transmit 
FIFO to the shift register where they are given a start bit and 
a parity bit (as programmed), and are shifted out to the TxD 
pin. The ESCC can generate an interrupt or DMA request 
depending on the status of the Transmit FIFO. If WR7' D5 
is reset, the transmit buffer empty interrupt and DMA 
request (either /W//REQ or /DTR//REQ pin) are asserted 
when the entry location of the Transmit FIFO is empty (one 
byte can be written). If WR7' D5 is set, the transmit interrupt 
and DMA request is generated when the Transmit FIFO is 
completely empty (four bytes can be written). The Transmit 
Buffer Empty (TBE) bit in RRO, bit D2 also is affected by the 
state of WR7' bit D5. The All Sent bit, bit DO of RR1 , can be 
polled to determine when the last bit of transmit data has 
cleared the TxD pin. 

The number of transmit interrupts can be minimized by 
setting bit D5 of WR7' to one and writing four bytes to the 
transmitter for each transmit interrupt/This requires that 
the system response to interrupt is less than the time it 
takes to transmit one byte at the programmed baud rate. 
If the system's interrupt response time is too long to use this 
feature, bit D5 of WR7' should be reset to 0. Then, poll the 
TBE bit and poll after each data write to test if there is space 
in the Transmit FIFO for more data. 

For details about the transmit DMA and transmit interrupts, 
refer to Section 2.4.8 "Transmit Interrupt and Transmit 
Buffer Empty bit". 

4.2.2 Asynchronous Receive 

Asynchronous mode is selected by specifying the number 
of stop bits per character in bits D3 and D2 of WR4. This 
selection applies only to the transmitter, however, as the 
receiver always checks for one stop bit. If after character 
assembly the receiver finds this stop bit to be a 0, the 
Framing Error bit in the receive error FIFO is set at the same 
time that the character is transferred to the receive data 
FIFO. This error bit accompanies the data to the exit 
location (CPU side) of the Receive FIFO, where it is a 
special receive condition. The Framing Error bit is not 
latched, so it must be read in RR1 before the accompany- 
ing data is read. 

The number of bits per character is controlled by bits D7 
and D6 of WR3. Five, six, seven or eight bits per character 
may be selected via these two bits. Data is right justified 
with the unused bits set to 1s. An additional bit, carrying 
parity information, may be selected by setting bit DO of 
WR4 to 1 . Note that this also enables parity for the transmit- 
ter. The parity sense is selected by bit D1 of WR4. If this bit 
is set to 1 , the received character is checked for even 
parity, and if set to 0, the received character is checked for 
odd parity. The additional bit per character that is parity is 



transferred to the receive data FIFO along with the data, if 
the data plus parity is eight bits or less. The parity error bit 
in the receive error FIFO may be programmed to cause 
special receive interrupts by setting bit D2 of WR1 to 1. 
Once set, this error bit is latched and remains active until 
an Error Reset command has been issued. 

Since errors apply to specific characters, it is necessary 
that error information moves alongside the data that it 
refers to. This is implemented in the SCC with an error FIFO 
in parallel with the data FIFO. The three error conditions 
that the receiver checks for in Asynchronous mode are: 

■ Framing errors - When a character's stop bit is a 0. 

■ Parity errors - The parity bit of a character disagrees 
with the sense programmed in WR4. 

■ Overrun errors - When the Receive FIFO overflows. 

If interrupts are not used to transfer data, the Parity Error, 
Framing Error, and Overrun Error bits in RR1 should be 
checked before the data is removed from the receive data 
FIFO, because reading data pops up the error information 
stored in the Error FIFO. 

The SCC may be programmed to accept a receive clock 
that is one, sixteen, thirty-two, or sixty-four times the data 
rate. This is selected by bits D7 and D6 in WR4. The 1X 
mode is used when bit synchronization external to the 
received clock is present (i.e., the clock recovery circuit, or 
active receive clock from the sender side). The 1 X mode is 
the only mode in which a data encoding method other than 
NRZ may be used. The clock factor is common to the 
receiver and transmitter. 

The break condition is continuous 0s, as opposed to the 
usual continuous ones during an idle condition. The SCC 
recognizes the Break condition upon seeing a null charac- 
ter (all 0s) plus a framing error. Upon recognizing this 
sequence, the Break bit in RRO is set and remains set until 
a 1 is received. At this point, the break condition is no 
longer present. At the termination of a break, the receive 
data FIFO contains a single null character, which should 
be read and discarded. The framing error bit will not be set 
for this character, but if odd parity has been selected, the 
Parity Error bit is set. 

Note: Caution should be exercised if the receive data line 
contains a switch that is not debounced to generate 
breaks. If this is the case, switch bounce may cause 
multiple breaks to be recognized by the SCC, with addi- 
tional characters assembled in the receive data FIFO and 
the possibility of a receive overrun condition being latched . 
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The SCC provides up to three modem control signals 
associated with the receiver; /SYNC, /DTR//REQ, 
and /DCD. 

The /SYNC pin is a general purpose input whose state is 
reported in the Sync/Hunt bit in RRO. If the crystal oscillator 
is enabled, this pin is not available and the Sync/Hunt bit 
is forced to 0. Otherwise, the /SYNC pin may be used to 
carry the Ring Indicator signal. 

The /DTR//REQ pin carries the inverted state of the DTR bit 
(D7) in WR5 unless this pin has been programmed to carry 
a DMA request signal. 

The /DCD pin is ordinarily a simple input to the DCD bit in 
RRO. However, if the Auto Enables mode is selected by 
setting D5 of WR3 to 1 , this pin becomes an enable for the 
receiver. That is, if Auto Enables is on and the /DCD pin is 
High, the receiver is disabled; while the/DCD pin is low, the 
receiver is enabled. 

Received characters are assembled, checked for errors, 
and moved to the receive data FIFO (eight bytes on ESCC, 
three bytes on NMOS/CMOS). The user can program the 
SCC to generate an interrupt to the CPU or to request a 
data read from a DMA when data is received. 

On the NMOS/CMOS version, it generates the Receive 
Character Available interrupt and DMA Request on Re- 
ceive (if enabled). The receive interrupt and DMA request 
is generated when there is at least one character in the 
FIFO. The Rx Character Available (RCA) bit is set if there 
is at least one byte available. 

The ESCC generates the receive character available inter- 
rupt and DMA request on Receive (if enabled) and is 
dependent on WR7' bit D3. If this bit is reset to (this mode 
is comparable to the NMOS/CMOS version), the receive 
interrupt and DMA request is generated when there is at 
least one character in the FIFO. If WR7 1 bit D3 is set to 1 , 
the receive interrupt and DMA request are generated 
when there are four bytes available in the Receive FIFO. 
The RCA bit in RRO follows the state of WR7' D3. The RCA 
bit is set if there is at least one byte available, regardless 
of the status of WR7' bit D3. 



This is the initialization sequence for the receiver in Asyn- 
chronous mode. First, WR4 selects the mode, then WR3 
and WR5 select the various options. At this point, the other 
registers should be initialized as necessary. When all of 
this is complete, the receiver may be enabled by setting bit 
DO of WR3 to1. 

See Section 2.4.7 "The Receive Interrupt" for more details 
on receive interrupts. 

4.2.3 Asynchronous Initialization 

The initialization sequence for Asynchronous mode is 
shown in Table 4-3. All of the SCC's registers should be re- 
initialized after a channel or hardware reset. Also, WR4 
should be programmed first after a reset. 



Table 4-3. Initialization Sequence Asynchronous 
Mode 



Reg 


Bit 


Description 




No 




WR9 


6,7 


Hardware or channel Reset 


WR4 


3,2 


Select Async Mode and the number 






of stop bits* 




0, 1 


Select parity* 




6,7 


Select clock mode* 


WR3 


7,6 


Select number of receive bits per 






character 




5 


Select Auto Enables Mode* 


WR5 


6,5 


Select number of bits/char for 






transmitter 




1 


Select modem control (RTS) 



Note: 

* Initializes transmitter and receiver simultaneously. 



At this point, the other registers should be initialized 
according to the hardware design such as clocking, 
I/O mode, etc. When this is completed, the transmitter is 
enabled by setting WR5 bit D3 to 1 and the receiver is 
enabled by setting WR3 bit DO to 1 . 
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4.3 BYTE-ORIENTED SYNCHRONOUS MODE 



The SCC supports three byte-oriented synchronous proto- 
cols. They are: monosynchronous, bisynchronous, and 
external synchronous. 

In synchronous communications, the bit cell boundaries 
are referenced to a clock signal common to both the 
transmitter and receiver. Consequently, they operate in a 
fixed-phase relationship. This eliminates the need for the 
receiver to locate the bit cell boundaries with a clock 16, 
32, or 64 times the receive data rate, allowing for higher 
speed communication links. Some applications may en- 
code (i.e., NRZI or FM coding) the clock information on the 
same line as the data. Therefore, these applications re- 
quire that the receiver use a high speed clock to find the bit 
cell boundaries (decoding is typically done with the PLL— 
Phase-Locked Loop; the SCC has on-chip Digital PLL). 
Data encoding eliminates the need to transmit the syn- 
chronous clock on a separate wire from the data. 

Synchronous data does not use start and stop bits to 
delineate the boundaries for each character. This eliminates 
the overhead associated with every character and in- 
creases the line efficiency. Because of the phase relation- 
ship of synchronous data to a clock, data is transferred in 



blocks with no gaps between characters. This requires 
that there be an agreement as to the location of the 
character boundaries so that the characters can be prop- 
erly framed. This is normally accomplished by defining 
special synchronization patterns, or Sync characters. The 
synchronization pattern serves as a reference; it signals 
the receiver that a character boundary occurs immediately 
after the last bit of the pattern. For example Monosync 
Protocol usually uses 1 6 Hex as this special character, and 
the SDLC protocol uses 0, six 1 s, followed by a (7E Hex; 
usually referred to as Flag Pattern) to mark the beginning 
and end of a block of data. Another way of identifying the 
character boundaries (i.e., achieving synchronization) is 
with a logic signal that goes active just as the first character 
is about to enter the receiver. This method is referred to as 
External Synchronization. 

Figure 4-4 shows the character format for synchronous 
transmission. For example, bits 1 -8 might be one character 
and bits 9-13 part of another character; or, bit 1 might be 
part of a second character, and bits 10-13 part of a third 
character. This is accomplished by defining a synchroni- 
zation character, commonly called a Sync Character. 



—►I Bit Time 

Modem Clock JllWIJlliri^^ 

Bit 1 2 3 4 5 6 7 8 9 10 11 12 13... 

Bit State 11 1000 11 01 01 01 

_lsbJ I n I LTLTLTL 

|^ Sync Character — — Data Character ■ 

Figure 4-4. Monosync Data Character Format 
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4.3.1 Byte-Oriented Synchronous Transmit 



Once Synchronous mode has been selected, any of three 
of the following sync character lengths may be selected: 

■ 6-bit 

■ 8-bit 

■ 16-bit 

The 6-bit option sync character is selected by setting bits 

4 and 5 of WR4 to zeros and bit of WR1 to one. Only the 
least significant six bits of WR6 are transmitted. 

The 8-bit sync character is selected by setting bits 4 and 

5 of WR4 to zeros and bit of WR10 to zeros. With this 
option selected, the transmitter sends the contents of WR6 
when it has no data to send. 

For a 16-bit sync character, set bit D4 of WR4 to 1 and bit 
D5 of WR4 and bit DO of WR10 to 0. In this mode, the 
transmitter sends the concatenation of WR6 and WR7 for 
the idle line condition. 

Because the receiver requires that sync characters be left- 
justified in the registers, whilethe transmitter requires them 
to be right justified, only the receiver works with a 12-bit 
sync character. While the receiver is in External Sync 
mode, the transmitter sync length may be six or eight bits, 
as selected by bit DO of WR10. 

Monosync and Bisync modes require clocking information 
to be transmitted along with the data either by a method of 
encoding data that contains clocking information, or by a 
modem that encodes or decodes clock information in the 
modulation process. Refer to the Monosync message 
format shown in Figure 4-4. 



The Bisync mode of operation is similar to the Monosync 
mode, except that two sync characters are provided 
instead of one. Bisync attempts a more structured ap- 
proach to synchronization through the use of special 
characters as message headers or trailers. 

Character-oriented mode is selected by programming bits 
D3 and D2 of WR4 with zeros. This selects Synchronous 
mode, as opposed to Asynchronous mode, but this selec- 
tion is further modified by bits 5 and 7 of WR4 as well as bits 
1 and of WR10. During the sync character-oriented 
modes, except in External Sync mode, the state of bits 7 
and 6 of WR4 are always forced internally to zeros. In 
external sync mode, these two bits must be programmed 
with zeros (Table 4-4.). The combination, other than 00 in 
External Sync mode, puts the SCO in special synchroniza- 
tion modes. 



Table 4-4. Registers Used in Character-oriented 
Modes 



Reg 


Bit No 


Description 


WR4 


3(=0) 
2(=0) 


select sync mode 




4(=0) 
5(=0) 
4(=1) 
5(=0) 


select monosync mode 
(8-bit sync character) 
select bisync mode 
(16-bit sync character) 




4(=1) 
5(=1) 
6(=0) 
7(=0) 


select external sync mode 
(external sync signal required) 
select 1x clock mode 


WR6 
WR7 
WR10 


7-0 
7-0 
1 


sync character (low byte) 
sync character (high byte) 
select sync character length 
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In character-oriented modes, a special bit pattern is used 
to provide character synchronization. The SCC offers 
several options to support Synchronous mode including 
various sync generation and checking, CRC generation 
and checking, as well as modem controls and a transmitter 
to receiver synchronization function. 

The number of bits per transmitted character is controlled 
by D6 and D5 of WR5 plus the way the data is formatted 
within the transmit buffer. The bits in WR5 select the option 
of five, six, seven, or eight bits per character. In all cases, 
the data must be right-justified, with the unused bits being 
ignored except in the case of five bits per character. When 
the five bits per character option is selected, the data must 
be formatted before being written to the transmit buffer to 
allow transmission of from one to five bits per character. 
This formatting is shown in Table 4-2. 

An additional bit, carrying parity information, may be 
automatically appended to every transmitted character by 
setting bit DO of WR4 to 1 . This parity bit is sent in addition 
to the number of bits specified in WR4 or by the data 
format. If this bit is set to 1 , the transmitter sends even 
parity; if set to 0, the transmitted parity is odd. Parity is not 
typically used in synchronous applications because the 
CRC provides a more reliable method for detecting errors. 

Either of two CRC polynomials are used in Synchronous 
modes, selected by bit D2 in WR5. If this bit is set to 1 , the 
CRC-16 polynomial is used and, if this bit is set to 0, the 
CRC-CCITT polynomial is used. This bit controls the se- 
lection for both the transmitter and receiver. The initial state 
of the generator and checker is controlled by bit D7 of 
WR10. When this bit is set to 1, both the generator and 
checker have an initial value of all ones; if this bit is set to 
0, the initial values are all zeros. 



The SCC does not automatically preset the CRC generator 
in byte Synchronous modes, so this must be done in 
software. This is accomplished by issuing the Reset Tx 
CRC Generator command, which is encoded in bits D7 
and D6 of WRO. For proper results, this command is issued 
while the transmitter is enabled and sending sync char- 
acters. 

If the CRC is to be used, the transmit CRC generator must 
be enabled by setting bit DO of WR5 to 1 . This bit may also 
be used to exclude certain characters from the CRC 
calculation. Sync characters (from sync registers) are 
automatically excluded from the CRC calculation, and any 
characters written as data are excluded from the calcula- 
tion by using bit DO of WR5. Internally, enabling or dis- 
abling the CRC for a particular character happens at the 
same time the character is loaded from the transmit data 
buffer (on the ESCC, the Transmit FIFO) to the Transmit 
Shift register. Thus, to exclude a character from the CRC 
calculation bit, DO of WR5 is set to before the character 
is written to the transmit buffer (on the ESCC, the Transmit 
FIFO). 

ESCC: 

Since the ESCC has a four-byte FIFO, if a character is to be 
excluded from the CRC calculation, it is recommended 
that only one byte be written to the ESCC at that time. If 
WR7' D5 is reset, the transmit interrupt is generated when 
the FIFO is completely empty. This can be used as a signal 
to reset WR5 bit DO, and then the character can be written 
to the Transmit FIFO. This guarantees that the internal 
disable occurs when the character moves from the buffer 
to the shift register. Once the buffer becomes empty, the 
Tx CRC Enable bit is written for the next character. 
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Enabling the CRC generator is not sufficient to control the 
transmission of the CRC. In the SCC, this function is 
controlled by the Tx Underrun/EOM bit, which is reset by 
the processor and set by the SCC. When the transmitter 
underruns (both the transmit buffer and Transmit Shift 
register are empty) the state of the Tx Underrun/EOM bit 
determines the action taken by the SCC. IftheTx Underrun/ 
EOM bit is reset when the underrun occurs, the transmitter 
sends the accumulated CRC and sets the Tx Underrun/ 
EOM bit to indicate this. This transition is programmed to 
cause an external/status interrupt, or the Tx Underrun/ 
EOM is available in RRO. 

The Reset Tx Underrun/EOM Latch command is encoded 
in bits D7 and D6 of WRO. For correct transmission of the 
CRC at the end of a block of data, this command is issued 
after the first character is written to the SCC but before the 
transmitter underruns. The command is usually issued 
immediately after the first character is written to the SCC so 
that the CRC is sent if an underrun occurs inadvertently 
during the block of data. 

ESCC: 

If WR7' bit D1 is set, the Reset Transmit Underrun/EOM 
latch is automatically reset after the first byte is written to 
the transmitter. This eliminates the need for the CPU to 
issue this command. This feature can be particularly useful 
to applications using a DMA to write data to the transmitter 
since there is no longer a need to interrupt the data 
transfers to issue this command. 

If the transmitter is disabled during the transmission of a 
character, that character is sent completely. This applies 
to both data and sync characters. However, if the transmit- 
ter is disabled during the transmission of the CRC, the 
16-bit transmission is completed, but the remaining bits 
will come from the Sync registers rather than the remainder 
of the CRC. 



There are two modem control signals associated with the 
transmitter provided by the SCC: /RTS and /CTS. 

The /RTS pin is a simple output that carries the inverted 
state of the RTS bit (D1 ) in WR5. 

The /CTS pin is ordinarily a simple input to the CTS bit in 
RRO. However, if Auto Enables mode is selected, this pin 
becomes an enable for the transmitter. That is, if Auto 
Enables is on and the /CTS pin is High, the transmitter is 
disabled. While the /CTS pin is Low, the transmitter is 
enabled. 

The initialization sequence for the transmitter in character- 
oriented mode is shown in Table 4-5. 



Table 4-5. Transmitter Initialization in Character- 
oriented Mode 



Reg 


Bit No 


Description 


WR4 


0,1 


selects parity (not typically used in 






sync modes) 


WR5 


1 


RTS 




2 


selects CRC generator 




5,6 


selects number of bits per character 


WR10 


7 


CRC preset value 



At this point, the other registers should be initialized as 
necessary. When all of this is completed, the transmitter is 
enabled by setting bit 3 of WR5 to one. Now that the 
transmitter is enabled, the CRC generator is initialized by 
issuing the Reset Tx CRC Generator command in WRO, 
bits 6-7. 
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4.3.2 Byte-Oriented Synchronous Receive 



The receiver in the SCC searches for character synchroni- 
zation only while it is in Hunt mode. In this mode the 
receiver is idle except that it is searching the incoming data 
stream for a sync character match. 

In Hunt mode, the receiver shifts for each bit into the 
Receive Shift register. The contents of the Receive Shift 
register are compared with the sync character (stored in 
another register), repeating the process until a match 
occurs. When a match occurs, the receiver begins trans- 
ferring bytes to the Receive FIFO. 

The receiver is in Hunt mode when it is first enabled, and 
it may be placed in Hunt mode by the processor issuing the 
Enter Hunt Mode command in WR3. This bit (D4) is a 
command, so writing a to it has no effect. The hunt status 
of the receiver is reported by the Sync/Hunt bit in RRO. 
Sync/Hunt is one of the possible sources of external/status 
interrupts, with both transitions causing an interrupt. This 
is true even if the Sync/Hunt bit is set as a result of the 
processor issuing the Enter Hunt Mode command. 

Once the sync character-oriented mode has been se- 
lected, any of the four sync character lengths may be 
selected: 6 bits, 8 bits, 12 bits, or 16 bits. 

The Table 4-6 shows the write register bit setting for 
selecting sync character length. 



Table 4-6. Sync Character Length Selection 


Sync Length 


WR4,D5 


WR4.D4 


WR10.D0 


6 bits 








1 


8 bits 











12 bits 





1 


1 


16 bits 





1 






The arrangement of the sync character in WR6 and WR7 is 
shown in Figure 4-5. 



For those applications requiring any other sync character 
length, the SCC makes provision for an external circuit to 
provide a character synchronization signal on the /SYNC 
pin. This mode is selected by setting bits D5and D4of WR4 
to 1 . In this mode, the Sync/Hunt bit in RRO reports the state 
of the /SYNC pin, but the receiver is still placed in Hunt 
mode when the external logic is searching for a sync 
character match. Two receive clock cycles after the last bit 
of the sync character is received, the receiver is in Hunt 
mode and the /SYNC pin is driven Low, then character 
assembly begins on the rising edge of the receive clock. 
This immediately precedes the activation of /SYNC 
(Figure 4-6). The receiver leaves Hunt mode when /SYNC 
is driven Low. 



Write Register 6 

| D7 1 D6 |D5 |D4 |D3 |D2 1 D1 [do| 



Sync7 Sync6 Sync5 Sync4 

Synd SyncO Sync5 Sync4 

Sync7 Sync6 Sync5 Sync4 

Sync3 Sync2 Synd SyncO 



ADR7 ADR6 
ADR7 ADR6 



ADR5 ADR4 
ADR5 ADR4 



Sync3 Sync2 Synd SyncO Monosync, 8 Bits 

Sync3 Sync2 Synd SyncO Monosync, 6 Bits 

Sync3 Sync2 Synd SyncO Bisync, 16 Bits 

,11 1 1 Bisync, 12 Bits 

ADR3 ADR2 ADR1 ADRO SDLC 

x x x x SDLC (Address Range) 



Write Register 7 



[P7 D6|D5|D4D3|D2 D1 Do| 



J 



Sync7 Sync6 Sync5 Sync4 Sync3 Sync2 Synd SyncO Monosync, 8 Bits 

Sync5 Sync4 Sync3 Sync2 Synd SyncO x x Monosync, 6 Bits 

Synd 5 Synd 4 Synd 3 Synd 2 Synd 1 SyndO Sync9 Sync8 Bisync, 16 Bits 

Sync11 SyndO Sync9 Sync8 Sync7 Sync6 Sync5 Sync4 Bisync, 12 Bits 

11 1 1 1 10 SDLC 



Figure 4-5. Sync Character Programming 
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RxD 



/SYNC 



^SYNC Last-1 ^"sYNC Last ^ Data 



Datal 




X 



Data 2 




DC 



Figure 4-6. /SYNC as an Input 



In all cases except External Sync mode, the /SYNC pin is 
an output that is driven Low by the SCC to signal that a sync 
character has been received. The /SYNC pin is activated 
regardless of character boundaries, so any external cir- 



cuitry using it should only respond to the /SYNC pulse that 
occurs while the receiver is in Hunt mode. The timing for 
the /SYNC signal is shown in Figure 4-7. 




To prevent sync characters from entering the receive data 
FIFO, set the Sync Character Load Inhibit bit (D1) in WR3 
to 1 . While this bit is set to 1 , characters about to be loaded 
into the receive data FIFO are compared with the contents 
of WR6. If all eight bits match the character, it is not loaded 
into the receive data FIFO. Because the comparison is 
across eight bits, this function should only be used with 8- 



bit sync characters. It cannot be used with 12- or 16-bit 
sync characters. Both leading sync characters are re- 
moved in the case of a 6-bit sync character. Care must be 
exercised in using this feature because sync characters 
which are not transferred to the receive data FIFO will 
automatically be excluded from CRC calculation. This 
works properly only in the 8-bit case. 
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The number of bits per character is controlled by bits D7 
and D6 of WR3. Five, six, seven, or eight bits per character 
may be selected via these two bits. The data is right- 
justified in the receive data buffer. The SCC merely takes 
a snapshot of the receive data stream at the appropriate 
times, so the "unused" bits in the receive buffer are only the 
bits following the character in the data stream. 

An additional bit carrying parity information is selected by 
setting bit DO of WR4 to 1 . Note that this also enables parity 
for the transmitter. The bit D1 of WR4 selects parity sense. 
If this bit is set to 1 , the received character is checked for 
even parity. If WR4 D1 is reset to 0, the received character 
is checked for odd parity. The additional bit per character 
is transferred to the FIFO as a part of data when the data 
plus parity is less than 8 bits per character. The Parity Error 



bit in the receive error FIFO may be programmed to cause 
a Special Receive Condition interrupt by setting bit D2 of 
WR1 to 1 . Once set, this error bit is latched and remains 
active until an Error Reset command has been issued. If 
interrupts are not used to transfer data, the Parity Error, 
CRC Error, and Overrun Error bits in RR1 should be 
checked before the data is removed from the receive 
data FIFO. 

The character length can be changed at any time before 
the new number of bits has been assembled by the 
receiver, but, care should be exercised as unexpected 
results may occur. A representative example would be 
switching from five bits to eight bits and back to five bits 
(Figure 4-8). 



Time 



Change from Five to Eight 



Receive Data Buffer 
| 8 7 6 5 4 3 2 ~T\ 5 Bits 

1 13 12 11 10 9 8 7 "eT| 8 Bits 



21 20 19 18 17 16 15 14 



8 Bits 



Change from Eight to Five 



1 29 28 27 26 25 24 23 22 1 5 Bits 



1 34 33 32 31 30 29 28 27| 5 Bits 



39 38 37 36 35 34 33 32 



Figure 4-8. Changing Character Length 



Either of two CRC polynomials are used in Synchronous 
modes, selected by bit D2 in WR5. If this bit is set to 1 , the 
CRC-16 polynomial is used, if this bit is set to 0, the CRC- 
CCITT polynomial is used. This bit controls the polynomial 
selection for both the receiver and transmitter. 

The initial state of the generator and checker is controlled 
by bit D7 of WR10. When this bit is set to 1, both the 
generator and checker have initial values of all ones; if this 



bit is set to 0, the initial values are all 0. The SCC presets 
the checker whenever the receiver is in Hunt mode so a 
CRC reset command is not necessary. However, there is 
a Reset CRC Checker command in WR0. This command is 
encoded in bits D7 and D6 of WR0. If the CRC is used, the 
CRC checker is enabled by setting bit DO of WR3 to 1 . 

Sync characters can be stripped from the data stream any 
time before the first non-sync character is received. If the 
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sync strip feature is not being used, the CRC is not enabled 
until after the first data character has been transferred to 
the receive data FIFO. As previously mentioned, 8-bit sync 
characters stripped from the data stream are automati- 
cally excluded from CRC calculation. 

Some synchronous protocols require that certain charac- 
ters be excluded from CRC calculation. This is possible in 
the SCC because CRC calculations are enabled and 
disabled on the fly. To give the processor sufficient time to 
decide whether or not a particular character should be 
included in the CRC calculation, the SCC contains an 8-bit 
time delay between the receive shift register and the CRC 
checker. The logic also guarantees that the calculation 



only starts or stops on a character boundary by delaying 
the enable or disable until the next character is loaded into 
the receive data FIFO. Because the nature of the protocol 
requires that CRC calculation disable/enable be selected 
before the next character gets loaded into the Receive 
FIFO, users cannot take advantage of the FIFO. 

To understand how this works refer to Figure 4-9 and the 
following explanation. Consider a case where the SCC 
receives a sequence of eight bytes, called A, B, C, D, E, F, 
G and H, with A received first. Now suppose that A is the 
sync character, the CRC is calculated on B, C, E, and F, 
and that F is the last byte of this message. This process is 
used to control the SCC. 



Receive Data 



[ 



] 



Receive Data FIFO 



3. 



3 Bytes Deep for NMOS/CMOS 
^ 8 Bytes Deep for ESCC 



h u A A A A it 

Receive Shift Register ] 



Eight Bit Time Delay ""] 



CRC Checker 



Figure 4-9. Receive CRC Data Path 
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Before A is received, the receiver is in Hunt mode and the 
CRC is disabled. When A is in the receive shift register, it 
is compared with the contents of WR7. Since A is the sync 
character, the bit patterns match and receive leaves Hunt 
mode, but character A is not transferred to the receive 
data FIFO. 

After eight-bit times, Bis loaded into the receive data FIFO. 
The CRC remains disabled even though somewhere dur- 
ing the next eight bit times the processor reads B and 
enables the CRC. Atthe end of this eight-bit time, B is in the 
8-bit delay and C is in the receive shift register. 

Character C is loaded into the receive data FIFO and at the 
same time the CRC checker becomes enabled. During the 
next eight-bit time, the processor reads C and since the 
CRC is enabled within this period, the SCC has calculated 
the CRC on B, character C is the 8-bit delay, and D is in the 
Receive Shift register. D is then loaded into the receive 
data FIFO and at some point during the next eight-bit time 
the processor reads D and disables the CRC. At the end 
of these eight-bit times, the CRC has been calculated on 
C, character D is in the 8-bit delay, and E is in the Receive 
Shift register. 

Now E is loaded into the receive data FIFO. During the next 
eight-bit time, the processor reads E and enables the CRC. 
During this time E shifts into the 8-bit delay, F enters the 
Receive Shift register and the CRC is not being calculated 
on D. After these eight-bit times have elapsed, E is in the 
8-bit delay, and F is in the Receive Shift register. Now F is 
transferred to the receive data FIFO and the CRC is 
enabled. During the next eight-bit times, the processor 
reads F and leaves the CRC enabled. The processor 
detects that this is the last character in the message and 
prepares to check the result of the CRC computation. 
However, another sixteen bit-times are required before the 
CRC has been calculated on all of character F. 

At the end of eight-bit times, F is in the 8-bit delay and G is 
in the Receive Shift register. At this time, it is transferred to 



the receive data FIFO. Character G is read and discarded 
by the processor. Eight-bit times later, H is also transferred 
to the receive data FIFO. The result of a CRC calculation is 
latched in to the Receive Error FIFO at the same time as 
data is written to the Receive Data FIFO. Thus, the CRC 
result through character F accompanies character H in the 
FIFO and will be valid in RR1 until character H is read from 
the Receive Data FIFO. The CRC checker is disabled and 
reset at any time after character H is transferred to the 
Receive Data FIFO. Recall, however, that internally the 
CRC is not disabled until after this occurs. A better alterna- 
tive is to place the receiver in Hunt mode, which automati- 
cally disables and resets the CRC checker. See Table 4- 
7 for a condensed description. 

Modem Controls. Up to two modem control signals asso- 
ciated with the receiver are available in Synchronous 
modes: /DTR//REQ and /DCD. The /DTR//REQ pin carries 
the inverted state of the DTR bit (D7) in WR5 unless this pin 
has been programmed to carry a DMA Request on Trans- 
mit signal. The /DCD pin is ordinarily a simple input to the 
DCD bit in RRO. However, if the Auto Enables mode is 
selected by setting D5 of WR3 to 1 , this pin becomes an 
enable for the receiver. Therefore, if Auto Enables is ON 
and the /DCD pin is High, the receiver is disabled; while the 
/DCD pin is Low, the receiver is enabled. 

Note that with Auto Enables mode enabled, when /DCD 
goes inactive, the receiver stops immediately and the 
character being assembled is lost. 

Initialization. The initialization sequence for the receiver in 
character-oriented mode is WR4 first, to select the mode, 
then WR10 to modify it if necessary; WR6 and WR7 to 
program the sync characters; WR3 and WR5 to select the 
various options. At this point the other registers are initial- 
ized as necessary. When all this is completed, the receiver 
is enabled by setting bit DO of WR3 to a one. A summary 
is shown in Table 4-8. A detailed example of using the SCC 
in 16-bit sync mode is available in the application note 
"SCC in Binary Synchronous Communications." 
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A 


B 


C 


D 


E 


F 


G 


H 


(Sync) 


(Datal) 


(Data2) 


(Data3) 


(CRC1) 


(CRC2) 


(Data) 


(Data) 



Note: No CRC Calculation on "D" 



Stage 



Direction of Data 
Coming into SCC 



Shift 
Register 



Receive 
Data FIFO 



Delay 
Register 



CRC 



Notes 



HGFEDCB A 



HGFEDCB 



HGFEDC 
CPU Reads 
CPU Enables CRC 



HGFED 
CPU Reads 



HGFE 
CPU Reads 
CPU Disables CRC 



D* 



HGF 
CPU Reads 
CPU Enables CRC 



HG 

CPU Reads 



H 

CPU Reads & Discard 



ReadRRI D6 
Read H & Discard 



H 
H 



CRC Calc on B 



CRC Calc on C 



CRC Calc is 
Disabled on D 



CRC Calc on E 
■► CRC Calc on F 



CRC Calc on F 
Result latched in 
Error FIFO t 



Legend: 

* Usually D is a end-of-message character indicator. 

t The status is latched on the Error FIFO for each received byte. In the calculation of F, 
the CRC error flag in the Error FIFO will be for an error free message, 
d = disabled 
e = enabled 

ABCDEFGH 

A = SYNC 

B - F = Data with E = CRC1 and F = CRC2 
G and H are arbitrary data (Pad Character) 



Table 4-7. Enabling and Disabling CRC 
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Table 4-8. Initializing the Receiver in Character-oriented Mode 


Reg 


D7 


D6 


D5 


Bit Number 
D4 D3 


D2 


D1 


DO 


Description 


WR4 











X 














Select x1 clock, enable sync mode, & no parity 
x=0 for 8 bit sync, x=1 for 16 bit sync 


WR3 


r 


X 





1 


1 











rx=# of Rx bits/char, No auto enable, enter Hunt, 
Enable Rx CRC, No sync character load inhibit 


WR5 


d 


t 


X 











r 


1 


d=inverse state of DTR pin, tx=# of Tx bits/char, 
use CRC-16, r=inverse state of /RTS pin, CRC enable 


WR6 
WR7 


X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


sync character, lower byte 
sync character, upper byte 


WR10 


c 











i 








s 


c=CRC preset, NRZ data, i=idle line condition 
s=size of sync character 


WR3 
WR5 
WRO 


r 
d 
1 


X 

t 






X 




1 




1 
1 









r 



1 
1 



Enable Receiver 
Enable Transmitter 
Reset CRC generator 



4.3.3 Transmitter/Receiver Synchronization 



The SCC contains a transmitter-to-receiver synchroniza- 
tion function that is used to guarantee that the character 
boundaries for the received and transmitted data are the 
same. In this mode, the receiver is in Hunt and the trans- 
mitter is idle, sending either all 1s or all Os. When the 
receiver recognizes a sync character, it leaves Hunt mode; 



one character time later the transmitter is enabled and 
begins sending sync characters. Beyond this point the 
receiver and transmitter are again completely indepen- 
dent, except that the character boundaries are now aligned 
(Figure 4-10). 



RxD 



TxD < 



Direction of Message Flow - 



\ I Sync I Sync I I 




Receiver Leaves Hunt 



Figure 4-10. Transmitter to Receiver Synchronization 



There are several restrictions on the use of this feature in 
the SCC. First, it only works with 6-bit, 8-bit or 16-bit sync 
characters. The data character length for both the receiver 
and the transmitter must be six bits with 6-bit sync charac- 
ter, and eight bits with an 8-bit or 1 6-bit sync character. Of 
course, the receive and transmit clocks must have the 
same rate as well as the proper phase relationship. 



A specific sequence of operations must be followed to 
synchronize the transmitter to the receiver. Both the re- 
ceiver and transmitter must have been initialized for opera- 
tion in Synchronous mode sometime in the past, although 
this initialization need not be redone each time the trans- 
mitter is synchronized to the receiver. The transmitter is 
disabled by setting bit D3 of WR5 to 0. At this point the 
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transmitter will send continuous 1s. If it is required that 
continuous Os be transmitted, the Send Break bit (D4) in 
WR5 is set to 1 . The transmitter is now idling but is still 
placed in the transmitter to receiver synchronization mode. 
This is accomplished by setting the Loop Mode bit (D1 ) in 
WR10 and then enabling the transmitter by setting bit D3 
of WR5 to 1 . At this point, the processor should set the Go 
Active on Poll bit (D4) in WR 1 0. The final step is to force the 



receiver to search for sync characters. If the receiver is 
currently disabled, the receiver enters Hunt mode when it 
is enabled, by setting bit DO of WR3 to 1 . If the receiver is 
already enabled, it is placed in Hunt mode by setting bit D4 
of WR3 to 1 . Once the receiver leaves Hunt mode, the 
transmitter is activated on the following character bound- 
ary. 



4.4 BIT-ORIENTED SYNCHRONOUS (SDLC/HDLC) MODE 



Synchronous Data Link Control mode (SDLC) uses syn- 
chronization characters similar to Bisync and Monosync 
modes (such as flags and pad characters). It is a bit- 
oriented protocol instead of a byte-oriented protocol. High 
level Data Link Control (HDLC) is defined as CCITT, also 
EIAJ and other standards; SDLC is one of the implemen- 
tations made by IBM®. The SDLC protocol uses the tech- 
nique of zero insertion to make all data transparent from 
SYNC characters. All references to SDLC in this manual 
apply to both SDLC and HDLC. 



The basic format for SDLC is a frame (Figure 4-11). A 
Frame is marked at the beginning and end by a unique flag 
pattern. The flags enclose an address, control, informa- 
tion, and frame check fields. There are many different 
implementations of the SDLC protocol and many do not 
use all of the fields. The SCC provides many features to 
control how each of the fields is received and transmitted. 



-Frame- 



Beginning Flag 
01111110 
8 Bits 





Address 


Control 




8 Bits 


8 Bits 



Information 
Any Number 
Of Bits 



Frame 
Check 
16 Bits 



Ending Flag 
01111110 
8 Bits 



Figure 4-1 1 . SDLC Message Format 



Frames of information are enclosed by a unique bit pattern 
called a flag. The flag character has a bit pattern of 
"01 111110" (7E Hex). This sequence of six consecutive 
ones is unique because all data between the opening and 
closing flags is prohibited from having more than five 
consecutive 1 s. The transmitter guarantees this by watch- 
ing the transmit data stream and inserting a after five 
consecutive 1s, regardless of character boundaries. In 
turn, the receiver searches the receive data stream for five 
consecutive 1 s and deletes the next bit if it is a 0. Since the 
SDLC mode does not use characters of defined length, but 
rather works on a bit-by-bit basis, the 01 1 1 1 1 10 flag can 
be recognized at any time. Inserted and removed 0s are 
not included in the CRC calculation. Since the transmis- 
sion of the flag character is excluded from the zero inser- 
tion logic, its transmission is guaranteed to be seen as a 
flag by the receiver. The zero insertion and deletion is 
completely transparent to the user. 

Because of the zero insertion/deletion, actual bit length on 
the transmission line may be longer than the number of bits 
sent. 



The two flags that delineate the SDLC frame serve as 
reference points when positioning the address and control 
fields, and they initiate the transmission error check. The 
ending flag indicates to the receiving station that the 16- 
bits just received constitute the frame check (CRC; also 
referred to as FCS or Frame Check Sequence). The ending 
flag can be followed by another frame, another flag, or an 
idle. This means that when two frames follow one another, 
the intervening flag may simultaneously be the ending flag 
of the first frame and the beginning flag of the next frame. 
This case is usually referred to as "Back-to-Back Frames". 

The SCC's SDLC address field is eight bits long and is 
used to designate which receiving stations accept a trans- 
mitted message. The 8-bit address allows up to 254 
(00000001 thru 11111110) stations to be addressed 
uniquely or a global address (1 1 1 1 1 1 1 1 ) is used to broad- 
cast the message to all stations. Address (00000000) is 
usually used as a Test packet address. 
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The control field of a SDLC frame is typically 8 bits, but can 
be any length. The control field is transparent to the SCC 
and is treated as normal data by the transmit and 
receive logic. 

The information field is not restricted in format or content 
and can be of any reasonable length (including zero). Its 
maximum length is that which is expected to arrive at the 
receiver error-free most of the time. Hence, the determi- 
nation of maximum length is afunction of the communication 
channel's error rate. Usually the upper layer of the protocol 
specifies the packet size. Although the data is always 
written/read in a given character size, the Residue Code 
feature provides the mechanism to read any number of bits 
at the end of the frame that do not make up a full character. 
This allows for the data field to be an arbitrary number of 
bits long. 

The frame check field is used to detect errors in the 
received address, control and information fields. The 
method used to test if the received data matches the 
transmitted data, is called a Cyclic Redundancy Check 
(CRC). The SCC has an option to select between two CRC 
polynomials, and in SDLC mode only the CRC-CCITT 
polynomial is used because the transmitter in the SCC 
automatically inverts the CRC before transmission. To 
compensate for this, the receiver checks the CRC result for 
the bit pattern 0001 1 1 01 00001 111. This is consistent with 
bit-oriented protocols such as SDLC, HDLC, and ADCCP 
and the others. 

There are two unique bit patterns in SDLC mode besides 
the flag sequence. They are the Abort and EOP (End of 
Poll) sequence. An Abort is a sequence of seven to thirteen 
consecutive 1 s and is used to signal the premature termi- 
nation of a frame. The EOP is the bit pattern 11111110, 
which is used in loop applications as a signal to a second- 
ary station that it may begin transmission. 

SDLC mode is selected by setting bit D5 of WR4 to 1 and 
bits D4, D3, and D2 of WR4 to 0. In addition, the flag 
sequence is written to WR7. Additional control bits for 
SDLC mode are located in WR10 and WR7' (ESCC). 

4.4.1 SDLC Transmit 

In SDLC mode, the transmitter moves characters from the 
transmitter buffer (on the ESCC, four-byte transmitter FIFO) 
to the Transmit Shift register, through the zero inserter and 
out to the TxD pin. The insertion of zero is completely 
transparent to the user. Zero insertion is done to all trans- 
mitted characters except the flag and abort. 

A SDLC frame must have the 01111110 (7E Hex) flag 
sequence transmitted before the data. This is done auto- 
matically by the SCC by programming WR7 with 7EH as 



part of the device initialization, enabling the transmitter, 
and then writing data. If the SCC is programmed to idle 
Mark (WR10 D3=1), special consideration must be taken 
to transmit the opening flag. Ordinarily, it is necessary to 
reset the WR10 D3 to idle flag, wait 8-bit times, and then 
write data to the transmitter. It is necessary to wait eight bit 
times before writing data because '1s' are transmitted 
eight at a time and all eight must leave the Transmit Shift 
register before a flag is loaded. 

The ESCC has two improvements over the NMOS/CMOS 
version to control the transmission of the flag at the begin- 
ning of a frame. Additionally, the ESCC has improved 
features to ease the handling of SDLC mode of operation, 
including afunction to deactivate the/RTS signal atthe end 
of the packet automatically. For these features, refer to the 
next subsection, 4.4.1.2, "ESCC Enhancements for 
SDLC Transmit." 

The number of bits per transmitted character is controlled 
by bits D6 and D5 of WR5 and the way the data is formatted 
within the transmit buffer. The bits in WR5 allow the option 
of five, six, seven, or eight bits per character. In all cases, 
the data must be right justified, with the unused bits being 
ignored, except in the case of five bits per character. When 
five bits per character are selected, the data may be 
formatted before being written to the transmit buffer. This 
allows transmission of one to five bits per character 
(Table 4-2). 

An additional bit, carrying parity information, is automati- 
cally appended to every transmitted character by setting 
bit DO of WR4 to 1 . This bit is sent in addition to the number 
of bits specified in WR4 or by the data format. The parity 
sense is selected by bit D1 of WR4. Parity is not normally 
used in SDLC mode as the overhead of parity is unneces- 
sary due to the availability of the CRC. 

The SCC transmits address and control fields as normal 
data and does not automatically send any address or 
control information. The value programmed into WR6 is 
used by the receiver to compare the address of the 
received frame (if address search mode is enabled), but 
WR6 is not used by the transmitter. Therefore, the address 
is written to the transmitter as the first byte of data in 
the frame. 

The information field can be any number of characters 
long. On the NMOS/CMOS version, the transmitter can 
interrupt the CPU when the transmit buffer is empty. On the 
ESCC, the transmitter can interruptthe CPU when the entry 
location of the Transmit FIFO is empty or when the Transmit 
FIFO is completely empty. Also, the NMOS/CMOS version 
can issue a DMA request when the transmit buffer is 
empty, while the ESCC can issue a DMA request when the 
entry location of the Transmit FIFO is empty or when the 
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Transmit FIFO is completely empty. This allows the ESCC 
user to optimize the response to the application require- 
ments. Since the ESCC has a four byte Transmit FIFO 
buffer, the Transmit Buffer Empty (TBE) bit (D2 of RRO) has 
a new definition as a FIFO-fullness status and is set when 
the entry location is full. For more details on this subject, 
refer to Section 2.4.8 "Transmit Interrupts and Transmit 
Buffer Empty bit". 

The character length may be changed on the fly, but the 
desired length must be selected before the character is 
loaded into the Transmit Shift register from the transmit 
data FIFO. The easiest way to ensure this is to write to WR5 
to change the character length before writing the data to 
the transmit buffer. Note that although the character can 
be any length, most protocols specify the address/control 
field as 8-bit fields. The SCC receiver checks the address 
field as 8-bit, if address search mode is enabled. 

Only the CRC-CCITT polynomial is used in SDLC mode. 
This is selected by setting bit D2 in WR5 to 0. This bit 
controls the selection for both the transmitter and receiver. 
The initial state of the generator and checker is controlled 
by bit D7 of WR10. When this bit is set to 1, both the 
generator and checker have an initial value of all 1s, and 
if this bit is set to 0, the initial values are all 0s. 

The SCC does not automatically preset the CRC genera- 
tor, so this is done in software. This is accomplished by 
issuing the Reset Tx CRC command, which is encoded in 
bits D7 and D6 of WRO. For proper results, this command 
is issued while the transmitter is enabled and idling. If the 
CRC is to be used, the transmit CRC generator is enabled 
by setting bit DO of WR5 to 1. The CRC is normally 
calculated on all characters between opening and closing 
flags, so this bit is usually set to 1 at initialization and never 
changed. On the ESCC with Auto EOM Latch reset mode 
enabled (WR7' bit D1=1), resetting of the CRC generator 
is done automatically. 

Enabling the CRC generator is not sufficient to control the 
transmission of the CRC. In the SCC, this function is 
controlled by Tx Underrun/EOM bit, which may be reset by 



the processor and set by SCC. On the ESCC with Auto 
EOM Reset mode enabled (WR7' bit D1=1), resetting of 
the Tx Underrun/EOM Latch is done automatically. 

Ordinarily, aframe is terminated with a CRC and a flag, but 
the SCC may be programmed to send an abort and a flag 
in place of the CRC. This option allows the SCC to abort a 
frame transmission in progress if the transmitter is acci- 
dentally allowed to underrun. This is controlled by the 
Abort/Flag on Underrun bit (D2) in WR10. When this bit is 
set to 1 , the transmitter will send an abort and a flag in place 
of the CRC when an underrun occurs. The frame is termi- 
nated normally with a CRC and a flag if this bit is 0. 

The SCC is also able to send an abort by a command from 
the processor. When the Send Abort command is issued 
in WRO, the transmitter sends eight consecutive 1s and 
then idles. Since up to five consecutive 1s may be sent 
prior to the command being issued, a Send Abort causes 
a sequence of from eight to thirteen 1s to be transmitted. 
The Send Abort command also clears the transmit 
data FIFO. 

When transmitting in SDLC mode, note that all data passes 
through the zero inserter, which adds an extra five bit times 
of delay between the Transmit Shift register and the 
TxD Pin. 

When the transmitter underruns (both the Transmit FIFO 
and Transmit Shift register are empty), the state of the Tx 
Underrun/EOM bit determines the action taken by 
the SCC. 

If the Tx Underrun/EOM bit is set to 1 when the underrun 
occurs, the transmitter sends flags without sending the 
CRC. If this bit is reset to when the underrun occurs, the 
transmitter sends either the accumulated CRC followed by 
flags, or an abort followed by flags, depending on the state 
of the Abort/Flag on the Underrun bit in the WR10, bit D1 . 
A summary is shown in Table 4-9. 

The Reset Tx Underrun/EOM Latch command is encoded 
in bits D7 and D6 of WRO. 



Table 4-9. ESCC Action Taken on Tx Underrun 



Tx Underrun/EOM Latch Bit 


Abort/Flag 


Action taken by ESCC upon transmit underrun 








Sends CRC followed by flag 





1 


Sends abort followed by flag 


1 


X 


Sends flag 
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The SCC sets the Tx Underrun/EOM latch when the CRC 
or abort is loaded into the shift register for transmission. 
This event can cause an interrupt, and the status of the Tx 
Underrun/EQM latch can be read in RRO. 

Resetting the Tx Underrun/EOM latch is done by the 
processor via the command encoded in bits D7 and D6 of 
WRO. On the ESCC, this also can be accomplished by 
setting WR7' bit D1 for Auto Tx Underrun/EOM Latch Reset 
mode enabled. For correct transmission of the CRC at the 
end of a frame, this command must be issued after the first 
character is written to the SCC but before the transmitter 
underruns after the last character written to the SCC. The 
command is usually issued immediately after the first 
character is written to the SCC so that the abort or CRC is 
sent if an underrun occurs inadvertently . The Abort/Flag on 
Underrun bit (D2) in WR10 is usually set to 1 at the same 
time as the Tx Underrun/EOM bit is reset so that an abort 
is sent if the transmitter underruns. The bit is then set to 
near the end of the frame to allow the correct transmission 
of the CRC. 

In this paragraph the term "completely sent" means shifted 
out of the Transmit Shift register, not shifted out of the zero 
inserter, which is an additional five bit times of delay. In 
SDLC mode, if the transmitter is disabled during transmis- 
sion of a character, that character will be "completely 
sent." This applies to both data and flags. However, if the 
transmitter is disabled during the transmission of the CRC, 
the 16-bit transmission will be completed, but the remain- 
ing bits are from the Flag register rather than the remainder 
of the CRC. 

The initialization sequence for the transmitter in SDLC 
mode is: 

1. WR4 selects the mode. 

2. WR10 modifies it if necessary. 
1 3. WR7 programs the flag. 

4 WR3 and WR5 selects the various options. 

At this point the other registers should be initialized as 
necessary. When all of this is complete, the transmitter 
may be enabled by setting bit D3 of WR5 to 1 . Now that the 
transmitter is enabled, the CRC generator may be initialized 
by issuing the Reset Tx CRC Generator command in WRO. 

4.4.1 .1 Modem Control signals related to SDLC Transmit 

There are two modem control signals associated with the 
transmitter provided by the SCC. The /RTS pin is a simple 
output that carries the inverted state of the RTS bit (D1) in 
WR5. The /CTS pin is ordinarily a simple input to the CTS 
bit in RRO. However, if Auto Enables mode is selected, this 
pin becomes an enable for the transmitter. If Auto Enables 
is on and the /CTS pin is High, the transmitter is disabled. 
The transmitter is enabled if the /CTS pin is Low. 



4.1 .1 .2 ESCC Enhancements for SDLC Transmit 
The ESCC has the following enhancements available in the 
SDLC mode of operation which can reduce CPU overhead 
dramatically. These features are: 

H Deeper Transmit FIFO (Four Bytes) 

■ CRC takes priority over the data 

■ Auto EOM Reset (WR7 1 bit D1) 

■ Auto Tx Flag (WR7' bit DO) 

■ Auto RTS Deactivation (WR7 1 bit D2) 

■ TxD pin forced High after closing flag in NRZI 
mode 

Deeper Transmit FIFO: The ESCC has a four byte deep 
Transmit FIFO, where the NMOS/CMOS version has a one 
byte deep transmit buffer. To maximize the system's per- 
formance, there are two modes of operation for the trans- 
mit interrupt and DMA request, which are programmed by 
bitD5ofWR7\ 

The ESCC sets WR7' bit D5 to 1 following a hardware or 
software reset. This is done to provide maximum compat- 
ibility with existing SCC designs. In this mode, the ESCC 
generates the transmit buffer empty interrupt and DMA 
transmit request when the Transmit FIFO is completely 
empty. Interrupt driven systems can maximize efficiency 
by writing four bytes for each entry into the Transmit 
Interrupt Service Routine (TISR), filling the Transmit FIFO 
without having to check any status bits. Since the TBE 
status bit is set if the entry location of the FIFO is empty, this 
bit can be tested at any time if more data is written. 
Applications requiring software compatibility with the 
NMOS/CMOS version can test the TBE bit in the TISR after 
each data write to determine if more data can be written. 
This allows a system with an ESCC to minimize the number 
of transmit interrupts, but not overflow SCC systems. DMA 
driven systems originally designed for the SCC can use 
this mode to reassert the DMA request for more data after 
the first byte written to the FIFO is loaded to the Transmit 
Shift register. Consequently, any subsequent reassertion 
allows the DMA sufficient time to detect the High-to-Low 
edge. 

If WR7' D5 is reset to 0, the transmit buffer empty interrupt 
and DMA request are generated when the entry location of 
the FIFO is empty. Therefore, if more than one byte is 
required to fill the entry location of the FIFO, the ESCC 
generates interrupts or DMA requests until the entry loca- 
tion of the FIFO is filled. The transmit DMA request pin 
(either /WAIT//REQ or /DTR//REQ) goes inactive after each 
data transfer, then goes active again and, consequently, 
generates a High-to-Low edge for each byte. Edge trig- 
gered DMA should be enabled before the transmit DMA 
function is enabled in the ESCC to guarantee that the 
ESCC does not generate the edge before the DMA is 
ready. 
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CRC takes priority overdata: On the NMOS/CMOS version, 
the data has higher priority over CRC data. Writing data 
before the Tx interrupt, after loading the closing flag into 
the Transmit Shift register, terminates the packet illegally. 
In this case, CRC byte(s) are replaced with Flag or Sync 
patterns, followed by the data written. On the ESCC, CRC 
has priority over the data. Consequently, after the Underrun/ 
EOM (End of message) interrupt occurs, the ESCC ac- 
cepts the data for the next packet without fear of collapsing 
the packet. On the ESCC, if data was written during the 
time period described above, the TBE bit (bit D2 of RRO) 
is NOT set; even if the 2nd TxlP is guaranteed to set when 
the flag/sync pattern is loaded into the Transmit Shift 
register (Section 2.4.8). For the detailed timing on this, 
refer to Figures 2-1 7 and 2-1 8. Hence, on the ESCC, there 
is no need to wait for the 2nd TxlP bit to set before writing 
data for the next packet which reduces the overhead. 

Auto EOM Reset (WR7 1 bit D1): As described above, the 
Tx Underrun/EOM Latch has to be reset before the Trans- 
mit Shift register completes shifting out the last character, 
but after first character has been written. One of the ways 
to reset it is for the CPU to issue the "Reset Tx Underrun/ 
EOM Latch" command. The other method to accomplish it 
is by the "Automatic EOM Latch Reset feature" by setting 
bit D1 in WR7', which is one of the enhancements made to 
the ESCC. By setting this bit to one, it eliminates the need 
for the CPU command. In this mode, the CRC generator is 
automatically reset at the start of every packet, without the 
CPU command. Hence, it is not required to reset the CRC 
generator prior to writing data into the ESCC. This is 
particularly valuable to a DMA driven system where issu- 
ing CPU commands while the DMA is transferring data is 
difficult. Also, it is very useful if the data rate is very high and 
the CPU may not be able to issue the command on time. 

Auto Tx Flag (WR7 1 bit DO): With the NMOS/CMOS version 
of the SCC, in order to accomplish Mark idle, it is required 
to enable the transmitter as Mark idle; then re-program to 
Flag idle before writing first data, and then re-program 
again to mark idle as described above. Normally, during 
mark idle, the transmitter sends continuous flags, but the 
ESCC can idle MARK under program control. By setting 
the Mark/Flag idle bit (D3) in WR10 to 1, the transmitter 



sends continuous 1s in place of the idle flags. The closing 
flag always transmits correctly even when this mode is 
selected. Normally, it is necessary to reset WR10 D3 to 
before writing data for the next frame. However, on the 
ESCC, if WR7' bit DO is set to 1, an opening flag is 
transmitted automatically and it is not necessary for the 
CPU to turn the Mark Idle feature on and off between 
frames. 

Note: When this mode in not in effect (WR7 1 D0=0), the 
Mark/Flag idle bit is clear to 0, allowing a flag to be 
transmitted before data is written to the transmit buffer. 
Care must be exercised in doing this because the continu- 
ous 1s are transmitted eight at a time and all eight must 
leave the Transmit Shift register. This allows a flag to be 
loaded into it before the first data is written to the 
Transmit FIFO. 

Auto RTS Deactivation (WR7' bit D2): Some applications 
require toggling the modem signal to indicate the end of 
the packet. With the NMOS/CMOS version, this requires 
intensive CPU support; the CPU needs time to determine 
whether or not the last bit of the closing flag has left the TxD 
pin. The ESCC has a new feature to deactivate the /RTS 
signal when the last bit of the closing flag clears the TxD 
pin. 

If this feature is enabled by setting bit D2 of WR7', and 
when WR5 bit D1 is reset during the transmission of a 
SDLC frame, the deassertion of the /RTS pin is delayed 
until the last bit of the closing flag clears the TxD pin. The 
/RTS pin is deasserted after the rising edge of the transmit 
clock cycle on which the last bit of the closing flag is 
transmitted. This implies that the ESCC is programmed for 
Flag on Underrun (WR10 bit D2=1) for the /RTS pin to 
deassertatthe end of the frame. (Otherwise, the deassertion 
occurs when the next flag is transmitted). This feature 
works independently of the programmed transmitter idle 
state. In Synchronous modes other than SDLC, the /RTS 
pin immediately follows the state programmed into WR5 
D1 . Note that if the /RTS pin is connected to one of the 
general purpose inputs (/CTS or /DCD), it can be used to 
generate an external status interrupt when a frame is 
completely transmitted. 
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NRZI forced High after closing flag: On the CMOS/NMOS 
version of the SCC in the SDLC mode of operation with 
NRZI mode of encoding and mark idle (WR10 bit D6=0, 
D5=1 , D3=1), the state of theTxD pin after transmission of 
the closing flag is undetermined, depending on the last 
data sent. With the ESCC in the same operation mode 
(SDLC, NRZI, with mark idle), the TxD pin is automatically 
forced High on the falling edge of the TxC of the last bit of 
the closing flag, and then the transmitter goes to the mark 
idle state. 

There are several different ways for a transmitter to go into 
the idle state. In each of the following cases, the TxD pin is 
forced High when the mark idle condition is reached; data, 
CRC (2 bytes), flag and idle; data, flag and idle; data, abort 
(on underrun) and idle; data, abort (by command) and idle; 
idle, flag and command to idle mark. The force High 
feature is disabled when the mark idle bit is reset (pro- 
grammed as mark idle). This feature is used in combina- 
tion with the automatic SDLC opening flag transmission 
feature, WR7' bit D0=1, to assure that data packets are 
properly formatted. When these features are used to- 
gether, it is not necessary for the CPU to issue any 
commands after sending a closing flag in combination with 
NRZI data encoding. (On the NMOS/CMOS version, this is 
accomplished by channel reset, followed by re-initializing 
the channel). If WR7' bit DO is reset, like in the NMOS/ 
CMOS version, it is necessary to reset the mark idle bit 
(WR10, bit D3) to enable flag transmission before a SDLC 
packet is transmitted. 



4.4.2 SDLC Receive 

The receiver in the SCC always searches the receive data 
stream for flag characters in SDLC mode. Ordinarily, the 
receiver transfers all received data between flags to the 
receive data FIFO. However, if the receiver is not in Hunt 
mode no data is received. The receiver is in Hunt mode 
when first enabled, or the receiver is placed in Hunt mode 
by the processor issuing the Enter Hunt mode command 
in WR3. This bit (D4) is a command, and writing a to it has 
no effect. The Hunt status of the receiver is reported by the 
Sync/Hunt bit in RRO. 

Sync/Hunt is one of the possible sources of external/status 
interrupts, with both transitions causing an interrupt. This 
is true even if the Sync/Hunt bit is set as a result of the 
processor issuing the Enter Hunt mode command. 

The receiver automatically enters Hunt mode if an abort is 
received. Because the receiver always searches the re- 
ceive data stream for flags, and automatically enters Hunt 
Mode when an abort is received, the receiver always 
handles frames correctly. The Enter Hunt Mode command 
should never be needed. The SCC drives the /SYNC pin 
Low to signal that a flag has been recognized, the timing 
for the /SYNC signal is shown in Figure 4-12. 
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Figure 4-12. /SYNC as an Output 
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The SCC assumes the first byte in an SDLC frame is the 
address of the secondary station for which the frame is 
intended. The SCC provides several options for handling 
this address. 

If the Address Search Mode bit (D2) in WR3 is set to 0, the 
address recognition logic is disabled and all received 
frames are transferred to the receive data FIFO. In this 
mode the software must perform any address recognition. 

If the Address Search Mode bit is set to 1 , only those 
frames whose address matches the address programmed 
in WR6 or the global address (all 1s) will be transferred to 
the receive data FIFO. 

The address comparison is across all eight bits of WR6 if 
the Sync Character Load inhibit bit (D1 ) in WR3 is set to 0. 
The comparison may be modified so that only the four most 
significant bits of WR6 match the received address. This 
mode is selected by setting the Sync Character Load 
inhibit bit to 1 . In this mode, however, the address field is 
still eight bits wide. The address field is transferred to the 



receive data FIFO in the same manner as data. It is not 
treated differently than data. 

The number of bits per character is controlled by bits D7 
and D6 of WR3. Five, six, seven, or eight bits per character 
may be selected via these two bits. The data is right- 
justified in the receive buffer. The SCC merely takes a 
snapshot of the receive data stream at the appropriate 
times, so the "unused" bits in the receive buffer are only the 
bits following the character. 

An additional bit carrying parity information is selected by 
setting bit D6 of WR4 to 1 . This also enables parity in the 
transmitter. The parity sense is selected by bit D1 of WR4. 
Parity is not normally used in SDLC mode. 

The character length can be changed at any time before 
the new number of bits have been assembled by the 
receiver. Care should be exercised, however, as unex- 
pected results may occur. A representative example, 
switching from five bits to eight bits and back to five bits, 
is shown in Figure 4-13. 
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Figure 4-13. Changing Character Length 
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Most bit-oriented protocols allow an arbitrary number of 
bits between opening and closing flags. The SCC allows 
for this by providing three bits of Residue Code in RR1. 
These indicate which bits in the last three bytes transferred 
from the receive data FIFO by the processor are actually 
valid data bits (and not part of the frame check sequence 
or CRC). Table 4-10 gives the meanings of the different 



codes for the four different character length options. The 
valid data bits are right-justified, meaning, if the number of 
valid bits given by the table is less than the character 
length, then the bits that are valid are the right-most or least 
significant bits. It should also be noted that the Residue 
Code is only valid at the time when the End of Frame bit in 
RR1 issetto 1. 



Table 4-10. Residue Codes 
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Code Previous Byte Previous Byte Previous Byte 
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As indicated in the table, these bits allow the processor to 
determine those bits in the information (and not CRC) field. 
This allows transparent retransmission of the received 
frame. The Residue Code bits do not go through a FIFO, so 
they change in RR1 when the last character of the frame is 
loaded into the receive data FIFO. If there are any charac- 
ters already in the receive data FIFO the Residue Code is 
updated before they are read by the processor. 



As an example of how the codes are interpreted, consider 
the case of eight bits per character and a residue code of 
101. The number of valid bits for the previous, second 
previous, and third previous bytes are 0, 7, and 8, respec- 
tively. This indicates that the information field (l-field) 
boundary falls on the second previous byte as shown in 
Figure 4-14. 
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Figure 4-14. Residue Code 101 Interpretation 



A frame is terminated by the detection of a closing flag. 
Upon detection of the flag the following actions take place: 
the contents of the Receive Shift Register are transferred 
to the receive data FIFO; the Residue Code is latched, the 
CRC Error bit is latched; the End of Frame upon reaching 
the top of the FIFO can cause a special receive condition. 
The processor then reads RR1 to determine the result of 
the CRC calculation and the Residue Code. 



Only the CRC-CCITT polynomial is used for CRC calcula- 
tions in SDLC mode, although the generator and checker 
can be preset to all 1 s or all 0s. The CRC-CCITT polynomial 
is selected by setting bit D2 of WR5 to 0. Bit D7 of WR10 
controls the preset value. If this bit is set to 1 , the generator 
and checker are preset to 1s, and if this bit is reset, the 
generator and checker are preset to all 0s. 
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The receiver expects the CRC to be inverted before 
transmission, so it checks the CRC result against the value 
0001 1 10100001 1 1 1 . The SCC presets the CRC checker 
whenever the receiver is in Hunt mode or whenever a flag 
is received, so a CRC reset command is not necessary. 
However, the CRC checker can be preset by issuing the 
Reset CRC Checker command in WRO. 

The CRC checker is automatically enabled for all data 
between the opening and closing flags by the SCC in 
SDLC mode, and the Rx CRC Enable bit (D3) in WR3 is 
ignored. The result of the CRC calculation for the entire 
frame is valid in RR1 only when accompanied by the End 
of Frame bit set in RR1 . At all other times, the CRC Error bit 
in RR1 should be ignored by the processor. 

On the NMOS/CMOS version, care must be exercised so 
that the processor does not attempt to use the CRC bytes 
that are transferred as data, because not all of the bits are 
transferred properly. The last two bits of CRC are never 
transferred to the receive data FIFO and are not recover- 
able. 

On the ESCC, an enhancement has been made allowing 
the 2nd byte of the CRC to be received completely. This 
feature is useful when the application requires the 2nd 
CRC byte as data. For example, applications which oper- 
ate in transparent mode or protocols using the error 
checking mechanism other than CRC-CCITT (like 
32-bit CRC). 

Note the following about SCC CRC operation: 

■ The normal CRC checking mechanism involves 
checking over data and CRC characters. If the division 
remainder is 0, there is no CRC error. 

■ SDLC is different. The CRC generator, when receiving 
a correct frame, has a fixed, non-zero remainder. The 
actual remainder in the receive CRC calculation is 
checked against this fixed value to determine if a CRC 
error exists. 

A frame is terminated by a closing flag. When the SCC 
recognizes this flag: 

■ The contents of the Receive Shift register are transferred 
to the receive data FIFO. 

■ The Residue Code is latched, the CRC Error bit is 
latched in the status FIFO and the End of Frame bit is 
set in the receive status FIFO. 



The End of Frame bit, upon reaching the exit location of the 
FIFO, will cause a special receive condition. The proces- 
sor may then read RR1 to determine the result of the CRC 
calculation as well as the Residue Code. If either the Rx 
Interrupt on Special Condition Only or the Rx Interrupt on 
First Character or Special Condition modes are selected, 
the processor must issue an Error Reset command in WRO 
to unlock the Receive FIFO. 

In addition to searching the data stream for flags, the 
receiver in the SCC also watches for seven consecutive 1 s, 
which is the abort condition. The presence of seven 
consecutive 1s is reported in the Break/Abort bit in RR0. 
This is one of the possible external/status interrupts, so 
transitions of this status may be programmed to cause 
interrupts. Upon receipt of an abort the receiver is forced 
into Hunt mode where it looks for flags. The Hunt status is 
also a possible external/status condition whose transition 
may be programmed to cause an interrupt. The transitions 
of these two bits occur very close together, but either one 
or two external/status interrupts may result. The abort 
condition is terminated when a is received, either by itself 
or as the leading of a flag. The receiver does not leave 
Hunt mode until a flag has been received, so two discrete 
external/status conditions occur at the end of an abort. An 
abort received in the middle of a frame terminates the 
frame reception, but not in an orderly manner because the 
character being assembled is lost. 

Up to two modem control signals associated with the 
receiver are available in SDLC mode: 

■ The /DTR//REQ pin carries an inverted state of the DTR 
bit (D7) in WR5 unless this pin has been programmed 
to carry a DMA Request signal. 

B The /DCD pin is ordinarily a simple input to the DCD bit 
in RR0. However, if the Auto Enables mode is selected 
by setting bit D5 of WR3 to 1, this pin becomes an 
enable for the receiver. That is, if Auto Enables is on 
and the /DCD pin is High, the receiver is disabled. 
While the /DCD pin is Low, the receiver is enabled. 

SDLC Initialization. The initialization sequence for SDLC 
mode is WR4 to select SDLC mode first, WR3 and WR5 to 
select the various options, WR7 to program flag, and then 
WR6 for the receive address. At this point the other 
registers should be initialized as necessary. When all this 
is completed the receiver is enabled by setting bit DO of 
WR3 to a one. A summary is shown in Table 4-1 1 . 
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Table 4-11. Initializing in SDLC Mode 
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Note: The receiver searches for synchronization when it is in Hunt mode. Note: The SYNC/HUNT bit in RRO reports the Hunt Status, and an interrupt 
In this mode, the receiver is idle except for searching the data stream for is generated upon transitions between the Hunt state and the Sync state, 
a flag match. 

Note: The SCC will drive the /SYNC pin Low for one receive clock cycle 
Note: When the receiver detects a flag match it achieves synchronization to signal that the flag has been received, 
and interprets the following byte as the address field. 



4.4.3 SDLC Frame Status FIFO 

This feature is not available on the NMOS version. 
On the CMOS version and the ESCC, the ability to receive 
high speed back-to-back SDLC frames is maximized by a 
10-bit deep by 19-bit wide status FIFO. When enabled 
(through WR15, bit D2), it provides a DMA the ability to 
continue to transfer data into memory so that the CPU can 
examine the message later. For each SDLC frame, a 1 4-bit 
byte count and five status/error bits are stored. The byte 
count and status bits are accessed through Read Regis- 
ters 6 and 7. Read Registers 6 and 7 are only accessible 
when the SDLC FIFO is enabled. The 1 0x1 9 status FIFO is 
separate from the 8-byte Receive Data FIFO. 

When the enhancement is enabled, the status in Read 
Register 1 (RR1) and byte count for the SDLC frame is 
stored in the 10x19 bit status FIFO. This allows the DMA 
controller to transfer the next frame into memory while the 
CPU verifies the message was properly received. 



Summarizing the operation; data is received, assembled, 
and loaded into the eight-byte FIFO before being trans- 
ferred to memory by the DMA controller. When a flag is 
received at the end of an SDLC frame, the frame byte count 
from the 14-bit counter and five status bits are loaded into 
the status FIFO for verification by the CPU. The CRC 
checker is automatically reset in preparation for the next 
frame which can begin immediately. Since the byte count 
and status are saved for each frame, the message integrity 
can be verified at a later time. Status information for up to 
10 frames can be stored before a status FIFO overrun 
occurs. 

If a frame is terminated with an ABORT, the byte count will 
be loaded to the status FIFO and the counter reset for the 
next frame. 

FIFO Detail. For a better understanding of details of the 
FIFO operation, refer to the block diagram in Figure 4-15. 
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Frame Status FIFO Circuitry 
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In SDLC Mode the following definitions apply. 

- All Sent bypasses MUX and equals contents of SCC Status Register. 

- Parity Bits bypasses MUX and does the same. 

- EOF is set to 1 whenever reading from the FIFO. 



Figure 4-15. SDLC Frame Status FIFO (N/A on NMOS) 
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Enable/Disable. The frame status FIFO is enabled when 
WR15 bit D2 is set and the CMOS/ESCC is in the SDLC/ 
HDLC mode. Otherwise, the status register contents by- 
pass the FIFO and go directly to the bus interface (the FIFO 
pointer logic is reset either when disabled or via a channel 
or Power-On Reset), The FIFO mode is disabled on power- 
up (WR1 5 D2 is set to on reset). The effects of backward 
compatibility on the register set are that RR4 is an image 
of RRO, RR5 is an image of RR1 , RR6 is an image of RR2 
and RR7 is an image of RR3. For the details of the added 
registers, refer to Chapter 5. The status of the FIFO Enable 
signal can be obtained by reading RR1 5 bit D2. If the FIFO 
is enabled, the bit is set to 1 ; otherwise, it is reset. 

Read Operation. When WR15 bit D2 is set and the FIFO is 
not empty, the next read to any of status register RR1 or the 
additional registers RR7 and RR6 is from the FIFO. Reading 
status register RR1 causes one location of the FIFO to be 
emptied, so status is read after reading the byte count, 
otherwise the count is incorrect. Before the FIFO underflows, 
it is disabled. In this case, the multiplexer is switched to 
allow status to read directly from the status register, and 
reads from RR7 and RR6 contain bits that are undefined. 
Bit D6 of RR7 (FIFO Data Available) is used to determine 
if status data is coming from the FIFO or directly from the 
status register, since it is set to 1 whenever the FIFO is 
not empty. 



Since not all status bits are stored in the FIFO, the All Sent, 
Parity, and EOF bits bypass the FIFO. The status bits sent 
through the FIFO are Residue Bits (3), Overrun, and CRC 
Error. 

The sequence for proper operation of the byte count and 
FIFO logic is to read the register in the following order: RR7, 
RR6, and RR1 (reading RR6 is optional). Additional logic 
prevents the FIFO from being emptied by multiple reads 
from RR1 . The read from RR7 latches the FIFO empty/full 
status bit (D6) and steers the status multiplexer to read 
from the CMOS/ESCC megacell instead of the status FIFO 
(since the status FIFO is empty). The read from RR1 allows 
an entry to be read from the FIFO (if the FIFO was empty, 
logic was added to prevent a FIFO underflow condition). 

Write Operation. When the end of an SDLC frame (EOF) 
has been received and the FIFO is enabled, the contents 
of the status and byte-count registers are loaded into the 
FIFO. The EOF signal is used to increment the FIFO. If the 
FIFO overflows, the RR7 bit D7 (FIFO Overflow) is set to 
indicate the overflow. This bit and the FIFO control logic is 
reset by disabling and re-enabling the FIFO control bit 
(WR15 bit 2). For details of FIFO control timing during an 
SDLC frame, refer to Figure 4-16. 
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Figure 4-16. SDLC Byte Counting Detail 



SDLC Status FIFO Anti-Lock Feature (ESCC only). When 
the Frame Status FIFO is enabled and the ESCC is pro- 
grammed for Special Receive Condition Only (WR1 
D4=D3=1), the data FIFO is not locked when a character 
with End of Frame status is read . When a character with the 
EOF status reaches the top of the FIFO, an interrupt with a 
vector for receive data is generated. The command Reset 
Highest IUS must be issued at the end of the interrupt 
service routine regardless of whether an interrupt ac- 
knowledge cycle had been executed (hardware or soft- 



ware). This allows a DMA to complete a transfer of the 
received frame to memory and then interrupt the CPU that 
a frame has been completed without locking the FIFO. 
Since in the Receive Interrupt on Special Condition Only 
mode the interrupt vector for receive data is not used, it is 
used to indicate that the last byte of a frame has been read 
from the Receive FIFO. This eliminates having to read the 
frame status (CRC and other status is stored in the status 
FIFO with the frame byte count). 
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When a character with a special receive condition other 
than EOF is received (receive overrun, or parity), a special 
receive condition interrupt is generated after the character 
is read from the FIFO and the Receive FIFO is locked until 
the Error Reset command is issued. 

4.4.4 SDLC Loop Mode 

The SCO supports SDLC Loop mode in addition to normal 
SDLC. SDLC Loop mode is very similar to normal SDLC but 
is usually used in applications where a point-to-point 
network is not appropriate (for example, Point-of-Sale 
terminals). In. an SDLC Loop, there is a primary controller 
that manages the message traffic flow on the loop and any 
number of secondary stations. In SDLC Loop mode, the 
SCC operating in regular SDLC mode can act as the 
primary controller. 

A secondary station in an SDLC Loop is always listening to 
the messages being sent around the loop, and in fact must 
pass these messages to the rest of the loop by retransmitting 
them with a one-bit-time delay. 

The secondary station can place its own message on the 
loop only at specific times. The controller signals that 
secondary stations may transmit messages by sending a 
special character, called an EOP (End of Poll), around the 
loop. The EOP character is the bit pattern 11111110. 

When a secondary station has a message to transmit and 
recognizes an EOP on the line, it changes the last binary 
1 of the EOP to a before transmission. This has the effect 
of turning the EOP into a flag pattern. The secondary 
station now places its message on the loop and terminates 
its message with an EOP. Any secondary stations further 
down the loop with messages to transmit can append their 
messages to the message of the first secondary station by 
the same process. 

All secondary stations without messages to send merely 
echo the incoming messages and are prohibited from 
placing messages on the loop, except upon recognizing 
an EOP. 

SDLC Loop mode is quite similar to normal SDLC mode 
except that two additional control bits are used. Writing a 
1 to the Loop Mode bit in WR10 configures the SCC for 
Loop mode. Writing a 1 to the Go Active on Poll bit in the 
same register normally causes the SCC to change the next 
EOP into a flag and then begin transmitting on loop. 
However, when the SCC first goes on loop it uses the first 
EOP as a signal to insert the one-bit delay, and doesn't 
begin transmitting until it receives the second EOP. There 
are also two additional status bits in RR10, the On-Loop bit 
and the Loop-Sending bit. 



There are also restrictions as to when and how a secondary 
station physically becomes part of the loop. 

A secondary station that has just powered up must monitor 
the loop, without the one-bit-time delay, until it recognizes 
an EOP. When an EOP is recognized the one-bit-time 
delay is switched on. This does not disturb the loop 
because the line is marking idle between the time that the 
controller sends the EOP and the time that it receives the 
EOP back. The secondary station that has gone on-loop 
cannot place a message on the loop until the next time that 
an EOP is issued by the controller. A secondary station 
goes off loop in a similar manner. When given a command 
to go off-loop, the secondary station waits until the next 
EOP to remove the one-bit-time delay. 

To operate the SCC in SDLC Loop mode, the SCC must 
first be programmed just as if normal SDLC were to be 
used. Loop mode is then selected by writing the appropri- 
ate control word in WR10. 

The SCC is now waiting for the EOP so that it can go on 
loop. While waiting for the EOP, the SCC ties TxD to RxD 
with only the internal gate delays in the signal path. When 
the first EOP is recognized by the SCC, the Break/Abort/ 
EOP bit is set in RRO, generating an External/Status inter- 
rupt (if so enabled). At the same time, the On-Loop bit in 
RR1 is set to indicate that the SCC is indeed on-loop, and 
a one-bit time delay is inserted in the TxD to the RxD path. 

The SCC is now on-loop but cannot transmit a message 
until a flag and the next EOP are received. The requirement 
that a flag be received ensures that the SCC cannot 
erroneously send messages until the controller ends the 
current polling sequence and starts another one. 

If the CPU in the secondary station with the SCC needs to 
transmit a message, the Go-Active-On-Poll bit in WR10 is 
set. If this bit is set when the EOP is detected, the SCC 
changes the EOP to a flag and starts sending another flag. 
The EOP is reported in the Break/Abort/EOP bit in RRO and 
the CPU writes its data bytes to the SCC, just as in normal 
SDLC frame transmission. When the frame is complete 
and CRC has been sent, the SCC closes with a flag and 
reverts to One-Bit-Delay mode. The last zero of the flag, 
along with the marking line echoed from the RxD pin, form 
an EOP for secondary stations further down the loop. 

While the SCC is actually transmitting a message, the loop- 
sending bit in R10 is set to indicate this. 

If the Go-Active-On-Poll bit is not set at the time the EOP 
passes by, the SCC cannot send a message until a flag 
(terminating the current polling sequence) and another 
EOP are received. 
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If SDLC loop is de-selected, the SCC is designed to exit 
from the loop gracefully. When the SDLC Loop mode is de- 
selected by writing to WR10, the SCC waits until the next 
polling cycle to remove the one-bit time delay. 

If a polling cycle is in progress at the time the command is 
written, the SCC finishes sending any message that it is 
transmitting, ends with an EOP, and disconnects TxD from 
RxD. If no message was in progress, the SCC immediately 
disconnects TxD from RxD. 

Once the SCC is not sending on the loop, exiting from the 
loop is accomplished by setting the Loop Mode bit in 
WR10 to 0, and at the same time writing the Abort/Flag on 
Underrun and Mark/Flag idle bits with the desired values. 
The SCC will revert to normal SDLC operation as soon as 
an EOP is received, or immediately if the receiver is already 
in Hunt mode because of the receipt of an EOP. 

To ensure proper loop operation after the SCC goes off the 
loop, and until the external relays take the SCC completely 
out of the loop, the SCC should be programmed for Mark 
idle instead of Flag idle. When the SCC goes off the loop, 
the On-Loop bit is reset. 

Note: With NRZI encoding, removing the stations from the 
loop (removing the one-bit time delay) may cause prob- 
lems further down the loop because of extraneous transi- 
tions on the line. The SCC avoids this problem by making 
transparent adjustments at the end of each frame it sends 
in response to an EOP. A response frame from the SCC is 
terminated by a flag and EOP. Normally, the flag and the 
EOP share a zero, but if such sharing would cause the RxD 
and TxD pins to be of opposite polarity after the EOP, the 
SCC adds another zero between the flag and the EOP. This 
causes an extra line transition so that RxD and TxD are 
identical after the EOP is sent. This extra zero is completely 
transparent because it only means that the flag and the 
EOP no longer share a zero. All that a proper loop exit 
needs, therefore, is the removal of the one-bit delay. 



The SCC allows the user the option of using NRZI in SDLC 
Loop mode by programming WR10 appropriately. With 
NRZI encoding, the outputs of secondary stations in the 
loop are inverted from their inputs because of messages 
that they have transmitted. 

Subsections 4.4.4.1 and 4.4.4.2 discuss the SDLC Loop 
Mode in Receive and Transmit. 

Note: Care must be exercised with the clock source used 
to receive and transmit data in the SDLC Loop mode of 
operation; particularly, when using PLL (Phase-Locked 
Loop) to recover the clocking information from data and 
use it as a transmit/receive clock source. In the SDLC Loop 
mode, the phase when the device is "passing through" the 
data, it is simply passing through the data only with the 
gate delay, while monitoring the receive data for the EOP 
sequence using the receive clock. When it goes onto the 
loop, the SCC inserts a one-bit time delay. When clocked 
by the transmit clock and if enabled to send, the SCC starts 
sending data using the transmit clock. The following are 
potential problems from the above analysis: 

■ Characteristics of the transmission line: It is possible 
that the transmission line (and the line driver) could 
add propagation delay. In this case, when the data is 
coming back to the primary station, it is possible that 
the phase of the data is totally off from that sent out the 
loop. 

■ When using a recovered receive clock as a source for 
the transmit clock: The data is sent using the clock with 
"jitters", because of the clock recovery. So the next 
secondary station and the following station(s) may not 
be able to lock their DPLL to the data. 

■ When the transmit clock is delivered from the free 
running clock source (this is also applicable to ESCC 
with internal DPLL), it is highly possible thatthe receive 
clock and transmit clock could be out of phase, 
resulting in improper operation. 
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4.4.4.1 SDLC Loop Mode Receive 



4.4.4.2 SDLC Loop Mode Transmit 



SDLC Loop mode is quite similar to SDLC mode except 
thattwo additional control bits are used. They are the Loop 
Mode bit (D1) and the Go-Active-On-Poll bit (D4) in WR10. 
In addition to these two extra control bits, there are also two 
status bits in RR10. They are the On Loop bit (D1) and the 
Loop Sending bit (D4). 

Before Loop mode is selected, both the receiver and 
transmitter have to be completely initialized for SDLC 
operation. Once this is done, Loop mode is selected by 
setting bit D1 of WRIOto 1 . At this point, the SCC connects 
TxD to RxD with only gate delays in the path. At the same 
time, a flag is loaded into the Transmit Shift register and is 
shifted to the end of the zero inserter, ready for transmis- 
sion. The SCC remains in this state until the Go-Active-On- 
Poll bit (D4) in WR1 is set to 1 . When this bit is set to 1 , the 
receiver begins looking for a sequence of seven consecu- 
tive 1s, indicating either an EOP or an idle line. When the 
receiver detects this condition, the Break/Abort bit in RRO 
is set to 1 , and a one-bit time delay is inserted in the path 
from RxD to TxD. 

The On-Loop bit in RR10 is also set to 1 at this time, and the 
receiver enters the Hunt mode. The SCC cannot transmit 
on the loop until a flag is received (causing the receiver to 
leave Hunt mode) and another EOP (bit pattern 11111110) 
is received. The SCC is now on the loop and capable of 
transmitting on the loop. As soon as this status is recog- 
nized by the processor, the Go-Active-On-Poll bit in WR10 
is set to to prevent the SCC from transmitting on the loop 
without a processor acknowledgement. 



To transmit a message on the loop, the Go-Active-On-Poll 
bit in WR10 must be set to 1 . Once this is done, the SCC 
changes the next received EOP into a Flag and begins 
transmitting on the loop. 

When the EOP is received, the Break/Abort and Hunt bits 
in RRO are set to 1 , and the Loop Sending bit in RR1 is also 
set to 1 . Data to be transmitted is written after the Go- 
Active-On-Poll bit has been set or after the receiver enters 
Hunt mode. 

If the data is written immediately after the Go-Active-On- 
Poll bit has been set, the SCC only inserts one flag after the 
EOP is changed into a flag. If the data is not written until 
after the receiver enters the Hunt mode, the flags are 
transmitted until the data is written. If only one frame is to 
be transmitted on the loop in response to an EOP, the 
processor must set the Go Active on Poll bit to before the 
last data is written to the transmitter. In this case, the 
transmitter closes the frame with a single flag and then 
reverts to the one-bit delay. 

The Loop Sending bit in RR1 is set to when the closing 
Flag has been sent. If more than one frame is to be 
transmitted, the Go-Active-On-Poll bit should not be set to 
until the last frame is being sent. If this bit is not set to 
before the end of a frame, the transmitter sends Flags until 
either more data is written to the transmitter, or until the Go- 
Active-On-Poll bit is set to 0. Note that the state of the Abort/ 
Flag on Underrun and Mark/Flag idle bits in WR10 is 
ignored by the SCC in SDLC Loop mode. 
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4.4.4.3 SDLC Loop Initialization 



The initialization sequence for the SCC in SDLC Loop 
mode is similar to the sequence used in SDLC mode, 
except that it is longer. The processor should program 
WR4 first to select SDLC mode, and then WR10 to select 
the CRC preset value and program the Mark/Flag idle bit. 



The Loop Mode and Go-Active-On-Poll bits in WR1 should 
not be set to 1 yet. The flag is written in WR7 and the various 
options are selected in WR3 and WR5. At this point, the 
other registers are initialized as necessary (Table 4-12). 



Table 4-12. SDLC Loop Mode Initialization 

Reg Bit Number Description 
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The Loop Mode bit (D1) in WR10 is set to 1 . When all of this 
is complete, the transmitter is enabled by setting bit D3 of 
WR5 to 1. Now that the transmitter is enabled, the CRC 
generator is initialized by issuing the Reset Tx CRC Gen- 
erator command in WRO. The receiver is enabled by 
setting the Go-Active-On-Poll bit (D4) in WR10 to 1. The 
SCC goes on the loop when seven consecutive 1s are 
received, and signals this by setting the On-Loop bit in 
RR10. Note that the seven consecutive 1s will set the 
Break/Abort and Hunt bits in RRO also. Once the SCC is on 
the loop, the Go-Active-On-Poll bit should be set to until 
a message is to be transmitted on the loop. To transmit a 
message on the loop, the Go-Active-On-Poll bit should be 
set to 1 . At this point, the processor may either write the first 



character to the transmit buffer and wait for a transmit 
buffer empty condition, or wait for the Break/Abort and 
Hunt bits to be set in RR1 and the Loop Sending bit to be 
set in RR10 before writing the first data to the transmitter. 
The Go-Active-On-Poll bit should be set to after the 
transition of the frame has begun. To go off of the loop, the 
processor should set the Go-Active-On-Poll bit in WR1 to 
and then wait for the Loop Sending bit in RR10 to be set 
to 0. At this point, the Loop Mode bit (D1 ) in WR10 is set to 
to request an orderly exit from the loop. The SCC exits 
SDLC Loop mode when seven consecutive 1s have been 
received; at the same time the Break/Abort and Hunt bits 
in RRO are set to 1, and the On Loop bit in RR10 is 
set to 0. 
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User's Manual 



5.1 INTRODUCTION 

This section describes the functions of the various bits in 
the registers of the SCC (Tables 5-1 and 5-2). Reserved 
bits are not used in this implementation of the device and 
may or may not be physically present in the device. For the 
register addresses, also refer to tables 2-1 , 2-2 and 2-5 in 
Chapter 2. Reserved bits that are physically present are 



Chapter 5 

REGISTER DESCRIPTIONS 



readable and writable but reserved bits that are not present 
will always be read as zero. To ensure compatibility with 
future versions of the device, reserved bits should always 
be written with zeros. Reserved commands are not used 
for the same reason. 



Table 5-1. SCC Write Registers 

Reg Description 

WRO Reg. pointers, various initialization commands 
WR1 Transmit and Receive interrupt enables, 

WAIT/DMA commands 
WR2 Interrupt Vector 

WR3 2 Receive parameters and control modes 
WR4 2 Transmit and Receive modes and parameters 
WR5 2 Transmit parameters and control modes 
WR6 Sync Character or SDLC address 

WR7 Sync Character or SDLC flag 

WR7' 1 Extended Feature and FIFO Control (WR7 Prime) 

WR8 Transmit buffer 

WR9 Master Interrupt control and reset commands 

WR10 Miscellaneous transmit and receive control bits 

WR1 1 Clock mode controls for receive and transmit 

WR12 Lower byte of baud rate generator 

WR13 Upper byte of baud rate generator 

WR14 Miscellaneous control bits 

WR15 External status interrupt enable control 



Notes for Tables 5-1 and 5-2: 

1 ESCConly. 

2 On the ESCC, these registers are readable as RR9.RR4.RR5, and 
RR1 1 , respectively, when WR7' D6=1 . Refer to the description of 
WR7 Prime for enabling the extended read capability. 

3 This feature is not available on NMOS. 



Table 5-2. SCC Read Registers 

Reg Description 

RRO Transmit and Receive buffer status and external 
status 

RR1 Special Receive Condition status 
RR2 Modified interrupt vector (Channel B only), 
Unmodified interrupt vector (Channel A only) 

RR3 Interrupt pending bits (Channel A only) 
RR4 2 Transmit and Receive modes and parameters 
(WR4) 

RR5 2 Transmit parameters and control modes (WR5) 
RR6 3 SDLC FIFO byte counter lower byte (only when 
enabled) 

RR7 3 SDLC FIFO byte count and status (only when 

enabled) 
RR8 Receive buffer 

RR9 2 Receive parameters and control modes (WR3) 
RR10 Miscellaneous status bits 



RR1 1 2 Miscellaneous transmit and receive control bits 
(WR10) 

RR12 Lower byte of baud rate generator time constant 
RR13 Upper byte of baud rate generator time constant 
RR1 4 2 Extended Feature and FIFO Control (WR7 Prime) 
RR15 External Status interrupt information 



5-1 



Among these registers, WR9 (Master Interrupt Control and 
Reset register) can be accessed through either channel. 
The RR2 (Interrupt Vector register) returns the interrupt 
vector modified by status, if read from Channel B, and 
written value (without modification), if read from Channel A. 

Channel A has an additional read register which contains 
all the Interrupt Pending bits (RR3A). 

Write Registers. Ten write registers are used for control; 
two for sync character generation/detection; two for baud 
rate generation. In addition, there are two write registers 
which are shared by both channels; one is the interrupt 
vector register (WR2); the other is the Master Interrupt and 
Reset register (WR9). On the ESCC, there is one additional 
register (WR7') to control enhanced features. 

See Table 5-1 for a summary of Write registers. 



Read Registers. Four read registers indicate status infor- 
mation; two are for baud rate generation; one for the 
receive buffer. In addition, there are two read registers 
which are shared by both channels; one for the interrupt 
pending bits; another for the interrupt vector. On the 
CMOS/ESCC, there are two additional registers, RR6 and 
RR7. They are available if the Frame Status FIFO feature 
was enabled in the SDLC mode of operation. On the ESCC, 
there is an "extended read" option and if its enabled, 
certain write registers can be read back. 

See Table 5-2 for a summary of Read registers. 



5.2 WRITE REGISTERS 

The SCC write register set in each channel has 1 1 control 
registers (includes transmit buffer/FIFO), two sync charac- 
ter registers, and two baud rate time constant registers. 
The interrupt control register and the master interrupt 
control and reset register are shared by both channels. In 
addition to these, the ESCC has a register (WR7'; prime 7) 
to control the enhancements from the NMOS/CMOS 
version. 

Between 80X30 and 85X30, the variation in register defini- 
tion is a command decode structure; Write Register 
(WRO). The following sections describe in detail each write 
register and the associated bit configuration for each. 

The following sections describe WR registers in detail: 

5.2.1 Write Register (Command Register) 

WRO is the command register and the CRC reset code 
register. WRO takes on slightly different forms depending 
upon whether the SCC is in the Z85X30 or the Z80X30. 
Figure 5-1 shows the bit configuration for the Z85X30 and 
includes register select bits in addition to command and 
reset codes. 

Figure 5-2 shows the bit configuration for the Z80X30 and 
includes (in Channel B only) the address decoding select 
described later. 

The following bit description for WRO is identical for both 
versions except where specified: 



Bits D7 and D6: CRC Reset Codes 1 And 0. 

Null Command (00). This command has no effect on the 
SCC and is used when a write to WRO is necessary for 
some reason other than a CRC Reset command. 

Reset Receive CRC Checker Command (01). This com- 
mand is used to initialize the receive CRC circuitry. It is 
necessary in synchronous modes (except SDLC) if the 
Enter Hunt Mode command in Write Register 3 is not 
issued between received messages. Any action that dis- 
ables the receiver initializes the CRC circuitry. Resetting 
the Receive CRC Checker command is accomplished 
automatically in SDLC mode. 

Reset Transmit CRC Generator Command (1 0). This com- 
mand initializes the CRC generator. It is usually issued in 
the initialization routine and after the CRC has been trans- 
mitted. A Channel Reset does not initialize the generator 
and this command is not issued until after the transmitter 
has been enabled in the initialization routine. 

On the ESCC, this command is not needed if Auto EOM 
Reset mode is enabled (WR7'D1=1). 

Reset Transmit Underrun/EOM Latch Command (1 1 ). This 
command controls the transmission of CRC at the end of 
transmission (EOM). If this latch has been reset, and a 
transmit underrun occurs, the SCC automatically appends 
CRC to the message. In SDLC mode with Abort on Underrun 
selected, the SCC sends an abort and Flag on underrun if 
the TX Underrun/EOM latch has been reset. 
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Write Register (non-multiplexed bus mode) 



D7 D6 D5 D4 D3 D2 D1 DO 



Register 

1 Register 1 

Register 2 

1 Register 3 

Register 4 

1 Register 5 

Register 6 

1 Register 7 

Register 8 ^ 

1 Register 9 

Register 10 

1 Register 1 1 

Register 12 

1 Register 13 
~ Register 14 



1 Register 15 



Null Code 

1 Point High 

Reset Ext/Status Interrupts 

1 Send Abort (SDLC) 

Enable Int on Next Rx Character 

1 Reset Tx Int Pending 

Error Reset 

1 Reset Highest IUS 



Null Code 

1 Reset Rx CRC Checker 

1 Reset Tx CRC Generator 

1 1 Reset Tx Underrun/EOM Latch 

* With Point High Command 



Figure 5-1. Write Register in the Z85X30 

Write Register (multiplexed bus mode) 
| D7 1 D6 1 D5 1 D4 | D3 1 D2 1 D1 | DO | 



Null Code 
Null Code 

Select Shift Left Mode 
Select Shift Right Mode 



Null Code 
Null Code 

Reset Ext/Status Interrupts 
Send Abort 

Enable Int on Next Rx Character 
Reset Tx Int Pending 
Error Reset 
Reset Highest IUS 



Null Code 

1 Reset Rx CRC Checker 

1 Reset Tx CRC Generator 

1 1 Reset Tx Underrun/EOM Latch 

* B Channel Only 



Figure 5-2. Write Register in the Z80X30 



interrupt command accompanies this command while the 
transmitter is disabled, an External/Status interrupt is gen- 
erated with the Tx Underrun/EOM bit reset in RRO. 

Bits D5-D3: Command Codes for the SCC. 

Null Command (000). The Null command has no effect on 
the SCC. 

Point High Command (001). This command effectively 
adds eight to the Register Pointer (D2-D0) by allowing 
WR8 through WR15 to be accessed. The Point High 
command and the Register Pointer bits are written simul- 
taneously. This command is used in the Z85X30 version of 
the SCC. Note that WRO changes form depending upon 
the SCC version. Register access for the Z80X30 version 
of the SCC is accomplished through direct addressing. 

Reset External/Status Interrupts Command (010). After an 
External/Status interrupt (a change on a modem line or a 
break condition, for example), the status bits in RRO are 
latched. This command re-enables the bits and allows 
interrupts to occur again as a result of a status change. 
Latching the status bits captures short pulses until the CPU 
has time to read the change. 

The SCC contains simple queueing logic associated with 
most of the external status bits in RRO. If another External/ 
Status condition changes while a previous condition is still 
pending (Reset External/Status Interrupt has not yet been 
issued) and this condition persists until after the command 
is issued, this second change causes another External/ 
Status interrupt. However, if this second status change 
does not persist (there are two transitions), another inter- 
rupt is not generated. Exceptions to this rule are detailed 
in the RRO description. 

Send Abort Command (011). This command is used in 
SDLC mode to transmit a sequence of eight to thirteen 1 s. 
This command always empties the transmit buffer and sets 
Tx Underrun/EOM bit in Read Register 0. 

Enable Interrupt On Next Rx Character Command (1 00). If 
the interrupt on First Received Character mode is se- 
lected, this command is used to reactivate that mode after 
each message is received. The next character to enter the 
Receive FIFO causes a Receive interrupt. Alternatively, 
the first previously stored character in the FIFO causes a 
Receive interrupt. 



At the start of the CRC transmission, the Tx Underrun/EOM 
latch is set. The Reset command can be issued at any time 
during a message. If the transmitter is disabled, this 
command does not reset the latch. However, if no External 
Status interrupt is pending, or if a Reset External Status 



Reset Tx Interrupt Pending Command (101). This com- 
mand is used in cases where there are no more characters 
to be sent; e.g., at the end of a message. This command 
prevents further transmit interrupts until after the next 
character has been loaded into the transmit buffer or until 
CRC has been completely sent. This command is neces- 
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sary to prevent the transmitter from requesting an interrupt 
when the transmit buffer becomes empty (with Transmit 
Interrupt Enabled). 

Error Reset Command (110). This command resets the 
error bits in RR1. If interrupt on first Rx Character or 
Interrupt on Special Condition modes is selected and a 
special condition exists, the data with the special condition 
is held in the Receive FIFO until this command is issued. If 
either of these modes is selected and this command is 
issued before the data has been read from the Receive 
FIFO, the data is lost. 

Reset Highest IUS Command (1 1 0). This command resets 
the highest priority Interrupt Under Service (IUS) bit, allow- 
ing lower priority conditions to request interrupts. This 
command allows the use of the internal daisy chain (even 
in systems without an external daisy chain) and is the last 
operation in an interrupt service routine. 

Bits 2 through 0: Register Selection Code 

On the Z85X30, these three bits select Registers through 
7. With the Point High command, Registers 8 through 15 
are selected (Table 5-3). 

In the multiplexed bus mode, bits D2 through DO have the 
following function. 

Bit D2 must be programmed as 0. Bits D1 and DO select 
Shift Left/Right; that is WRO (1-0)=10 for shift left and WRO 
(1-0)= 11 for shift right. See Section 2.1 .4 for further details 
on Z80X30 register access. 

5.2.2 Write Register 1 (Transmit/Receive 
Interrupt and Data Transfer Mode Definition) 

Write Register 1 is the control register for the various SCC 
interrupt and Wait/Request modes. Figure 5-3 shows the 
bit assignments for WR1 . 

Bit 7: WAIT/DMA Request Enable. 

This bit enables the Wait/Request function in conjunction 
with the Request/Wait Function Select bit (D6). 



Write Register 1 

D7| D6| D5| D4| D3 1 D2 1 D1 1 DO 




Ext Int Enable 
Tx Int Enable 
Parity is Special Condition 



Rx Int Disable 

1 Rx Int On First Character or Special Condition 

1 Int On All Rx Characters or Special Condition 
1 1 Rx Int On Special Condition Only 

WAIT/DMA Request On 

Receive//Transmit 

— — — — — — AVAIT/DMA Request Function 

WAIT/DMA Request Enable 

Figure 5-3. Write Register 1 



When programmed to 0, the selected function (bit 6) forces 
the /W//REQ pin into the appropriate inactive state (High 
for Request, floating for Wait). 

When programmed to 1 , the state of bit 6 determines the 
activity of the /W//REQ pin (Wait or Request). 

Bit 6: WAIT/DMA Request Function. 

When programmed to 0, the Wait function is selected. In 
the Wait mode, the /W//REQ pin switches from floating to 
Low when the CPU attempts to transfer data before the 
SCC is ready. 

When programmed to 1 , the Request function is selected. 
In the Request mode, the /W//REQ pin switches from High 
to Low when the ESCC is ready to transfer data. 

Bit 5: /WAIT//REQUEST on Transmit or Receive. 

When programmed to 0, the state of the /W//REQ pin is 
determined by bit 6 and the state of the transmit buffer. 

Note: A transmit request function is available on the 
/DTR//REQ pin. This allows full-duplex operation under 
DMA control for both channels. 
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Table 5-3. Z85X30 Register Map 
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o 
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RROB 


RROB 
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RR1B 
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RR1B 








1 





WR2 


RR2B 


RR2B 


RR2B 








1 


1 


WR3B 


RR3B 


RR3B 


RR3B 





1 








\»/n A n 

WR4B 


(RROB) 


(RROB) 


/\ A/f""> A l~) Y 

(WR4B) 





1 





1 


WR5B 


(RR1B) 


(RR1B) 


(WR5B) 
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1 
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(RR2B) 
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RR6B 
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1 


1 


WR7B 


(RR3B) 


RR7B 


RR7B 














\ a /nn a 
WHOA 


nnn a 

HHOA 


HHOA 


nnr> A 

HHOA 











1 


WR1A 


RR1A 


RR1A 


RR1A 








1 





WR2 


RR2A 


RR2A 


RR2A 








1 


1 


WR3A 


RR3A 


RR3A 


RR3A 





1 








V A/D A A 

WR4A 


/nr)A A \ 

(RROA) 


(RROA) 


AA/D/I A \ 

(WH4A) 





1 





1 


WHO A 


(nn 1A) 


(nnlA; 


AA/DC A\ 

(VVnOAJ 





1 


1 





WR6A 


(RR2A) 


RR6A 


□ DC A 

HHbA 





1 


1 


1 


WR7A 


(RR3A) 


RR7A 


RR7A 


With Point High Command 




















o 


WHod 


DDOD 

nnoD 


DDQD 

nnoD 


DDQD 

nnoD 










1 


WR9 


(RR13B) 


(RR13B) 


(WR3B) 







1 





WR10B 


RR10B 


RR10B 


RR10B 







1 


1 


WR11B 


(RR15B) 


(RR15B) 


(WR10B) 




1 










\«fOH on 

WR 12B 


RR12B 


HHI^D 


DDH OD 
HR 




1 





1 


WR13B 


RR13B 


RR13B 


RR13B 




1 


1 





WR14B 


RR14B 


RR14B 


(WR7'B) 




1 


1 


1 


WR15B 


RR15B 


RR15B 


RR15B 













\ A/no A 

WR8A 


RR8A 


DDO A 

RR8A 


DDO A 

HRoA 










1 


WR9A 


(RR13A) 


(RR13A) 


(WR3A) 







1 


u 


\A/DH/~»A 

WRlOA 


nnlOA 


DDH OA 

nn 1UA 


DDH riA 

nn IOA 







1 


1 


WR11A 


(RR15A) 


(RR15A) 


(WR10A) 




1 








WR12A 


RR12A 


RR12A 


RR12A 




1 





1 


WR13A 


RR13A 


RR13A 


RR13A 




1 


1 





WR14A 


RR14A 


RR14A 


(WR7'A) 




1 


1 


1 


WR15A 


RR15A 


RR15A 


RR15A 



Notes: 

WR15 bit D2 enables status FIFO function. (Not available on NMOS) 
WR7' bit D6 enables extend read function. (Only on ESCC) 
* Includes 85C30 and 85230 with WR15 D2=0. 
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When programmed to 1, this bit allows the Wait/Request 
function to follow the state of the receive buffer. Thus, 
depending on the state of bit 6, the /W//REQ pin is active 
or inactive in relation to the empty or full state of the receive 
buffer. 

The request function occurs only when the SCC is not 
selected; e.g., if the internal request becomes active while 
the SCC is in the middle of a read or write cycle, the 
external request does not become active until the cycle is 
complete. An active request output causes a DMA control- 
ler to initiate a read or write operation. If the request on 
Transmit mode is selected in either SDLC or Synchronous 
Mode, the Request pin is pulsed Low for one PCLK cycle 
at the end of CRC transmission to allow the immediate 
transmission of another block of data. 

In the Wait On Receive mode, the /WAIT pin is active if the 
CPU attempts to read SCC data that has not yet been 
received. In the Wait On Transmit mode, the /WAIT pin is 
active if the CPU attempts to write data when the transmit 
buffer is still full. Both situations occur frequently when 
block transfer instructions are used. 

Bits 4 and 3: Receive Interrupt Modes. 

Receive Interrupts Disabled (00). This mode prevents the 
receiver from requesting an interrupt. It is normally used in 
a polled environment where either the status bits in RRO or 
the modified vector in RR2 (Channel B) are monitored to 
initiate a service routine. Although the receiver interrupts 
are disabled, a special condition can still provide a unique 
vector status in RR2. 

Receive Interrupt on First Character or Special 
Condition (01). The receiver requests an interrupt in this 
mode on the first available character (or stored FIFO 
character) or on a special condition. Sync characters, 
stripped from the message stream, do not cause inter- 
rupts. 

Special receive conditions are: receiver overrun, framing 
error, end of frame, or parity error (if selected). If a special 
receive condition occurs, the data containing the error is 
stored in the Receive FIFO until an Error Reset command 
is issued by the CPU. 

This mode is usually selected when a Block Transfer mode 
is used. In this interrupt mode, a pending special receive 
condition remains set until either an error Reset command, 
a channel or hardware reset, or until receive interrupts are 
disabled. 

The Receive Interrupt on First Character or Special Condi- 
tion mode can be re-enabled by the Enable Rx Interrupt on 
Next Character command in WRO. 



ESCC: 

See the description of WR7' on how this function can be 
changed. 

Interrupt on All Receive Characters or Special Condition 
(10). This mode allows an interrupt for every character 
received (or character in the Receive FIFO) and provides 
a unique vector when a special condition exists. The 
Receiver Overrun bit and the Parity Error bit in RR1 are two 
special conditions that are latched. These two bits are 
reset by the Error Reset command. Receiver overrun is 
always a special receive condition, and parity can be 
programmed to be a special condition. 

Data characters with special receive conditions are not 
held in the Receive FIFO in the Interrupt On All Receive 
Characters or Special Conditions Mode as they are in the 
other receive interrupt modes. 

Receive Interrupt on Special Condition (11). This mode 
allows the receiver to interrupt only on characters with a 
special receive condition. When an interrupt occurs, the 
data containing the error is held in the Receive FIFO until 
an Error Reset command is issued. When using this mode 
in conjunction with a DMA, the DMA is initialized and 
enabled before any characters have been received by the 
ESCC. This eliminates the time-critical section of code 
required in the Receive Interrupt on First Character or 
Special Condition mode. Hence, all data can be trans- 
ferred via the DMA so that the CPU need not handle the first 
received character as a special case. In SDLC mode, if the 
SDLC Frame Status FIFO is enabled and an EOF is 
received, an interrupt with vector for receive data available 
is generated and the Receive FIFO is not locked. 

Bit 2: Parity Is Special Condition. 

If this bit is set to 1 , any received characters with parity not 
matching the sense programmed in WR4 give rise to a 
Special Receive Condition. If parity is disabled (WR4), this 
bit is ignored. A special condition modifies the status of the 
interrupt vector stored in WR2. During an interrupt ac- 
knowledge cycle, this vector can be placed on the 
data bus. 

Bit 1 : Transmitter Interrupt Enable. 

If this bit is set to 1, the transmitter requests an interrupt 
whenever the transmit buffer becomes empty. 

Bit 0: External/Status Master Interrupt Enable. 

This bit is the master enable for External/Status interrupts 
including /DCD, /CTS, /SYNC pins, break, abort, the be- 
ginning of CRC transmission when the Transmit/Underrun/ 
EOM latch is set, or when the counter in the baud rate 



generator reaches 0. Write Register 15 contains the indi- 
vidual enable bits for each of these sources of External/ 
Status interrupts. This bit is reset by a channel or 
hardware reset. 

5.2.3 Write Register 2 (Interrupt Vector) 

WR2 is the interrupt vector register. Only one vector 
register exists in the SCC, and it can be accessed through 
either channel. The interrupt vector can be modified by 
status information. This is controlled by the Vector Includes 
Status (VIS) and the Status High/Status Low bits in WR9. 
The bit positions for WR2 are shown in Figure 5-4. 



Bits 7 and 6: Receiver Bits/Character. 

The state of these two bits determines the number of bits 
to be assembled as a character in the received serial data 
stream. The number of bits per character can be changed 
while a character is being assembled, but only before the 
number of bits currently programmed is reached. Unused 
bits in the Received Data Register (RR8) are set to 1 in 
asynchronous modes. In Synchronous and SDLC modes, 
the SCC merely transfers an 8-bit section of the serial data 
stream to the Receive FIFO at the appropriate time. Table 
5-4 lists the number of bits per character in the assembled 
character format. 



Write Register 2 

E 



D6 1 D5 1 D4 1 D3 1 D2 



IE] 



vo 

V1 
V2 
V3 
V4 
V5 
V6 
V7 J 



> Interrupt 
Vector 



Figure 5-4. Write Register 2 



5.2.4 Write Register 3 (Receive Parameters 
and Control) 

This register contains the control bits and parameters for 
the receiver logic as illustrated in Figure 5-5. On the ESCC, 
with the Extended Read option enabled, this register may 
be read as RR9. 

Write Register 3 



I D7 1 D6 1 D5 I D4 1 D3 1 D2 I D1 I DO I 



L_ 



Rx Enable 

Sync Character Load Inhibit 
Address Search Mode (SDLC) 
Rx CRC Enable 
Enter Hunt Mode 
Auto Enables 



Rx 5 Bits/Character 

1 Rx 7 Bits/Character 

1 Rx 6 Bits/Character 
1 1 Rx 8 Bits/Character 



Figure 5-5. Write Register 3 



Table 5-4. Receive Bits per Character 


D7 


D6 


Bits/Character 








5 





1 


7 


1 





6 


1 


1 


8 



Bit 5: Auto Enable. 

This bit programs the function for both the /DCD and /CTS 
pins. /CTS becomes the transmitter enable and /DCD 
becomes the receiver enable when this bit is set to 1 . 
However, the Receiver Enable and Transmit Enable bits 
must be set before the /DCD and /CTS pins can be used 
in this manner. When the Auto Enable bit is set to 0, the 
/DCD and /CTS pins are inputs to the corresponding status 
bits in Read Register 0. The state of /DCD is ignored in the 
Local Loopback mode. The state of /CTS is ignored in both 
Auto Echo and Local Loopback modes. 

Bit 4: Enter Hunt Mode. 

This command forces the comparison of sync characters 
or flags to assembled receive characters for the purpose 
of synchronization. After reset, the SCC automatically 
enters the Hunt mode (except asynchronous). Whenever 
a flag or sync character is matched, the Sync/Hunt bit in 
Read Register is reset and, if External/Status Interrupt 
Enable is set, an interrupt sequence is initiated. The SCC 
automatical ly enters the Hunt mode when an abort condition 
is received or when the receiver is enabled. 

Bit 3: Receiver CRC Enable. 

This bit is used to initiate CRC calculation at the beginning 
of the last byte transferred from the Receiver Shift register 
to the Receive FIFO. This operation occurs independently 
of the number of bytes in the Receive FIFO. When a 
particular byte is to be excluded from the CRC calculation, 
this bit should be reset before the next byte is transferred 
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to the Receive FIFO. If this feature is used, care must be 
taken to ensure that eight bits per character is selected in 
the receiver because of an inherent delay from the Receive 
Shift register to the CRC checker. 

This bit is internally set to 1 in SDLC mode and the SCC 
calculates the CRC on all bits except zeros inserted 
between the opening and closing flags. This bit is ignored 
in asynchronous modes. 



each source (if each station address has the four most 
significant bits in common). The address field in the frame 
is still eight bits long. Address FFH is always recognized as 
a global address. 

The bit is ignored in SDLC mode if Address Search mode 
has not been selected. 

BitO: Receiver Enable. 



Bit 2: Address Search Mode (SDLC). 

Setting this bit in SDLC mode causes messages with 
addresses not matching the address programmed in WR6 
to be rejected. No receiver interrupts occur in this mode 
unless there is an address match. The address that the 
SCC attempts to match is unique (1 in 256) or multiple 
(1 6 in 256), depending on the state of Sync Character Load 
Inhibit bit. Address FFH is always recognized as a global 
address. The Address Search mode bit is ignored in all 
modes except SDLCl 

Bit 1 : SYNC Character Load Inhibit. 

If this bit is set to 1 in any mode except SDLC, the SCC 
compares the byte in WR6 with the byte about to be stored 
in the FIFO, and it inhibits this load if the bytes are equal. 
(Caution: this also occurs in the asynchronous mode if the 
received character matches the contents of WR6.) The 
SCC does not calculate the CRC on bytes stripped from 
the data stream in this manner. If the 6-bit sync option is 
selected while in Monosync mode, the comparison is still 
across eight bits, so WR6 is programmed for proper 
operation. 

If the 6-bit sync option is selected with this bit set to 1 , all 
sync characters except the one immediately preceding 
the data are stripped from the message. If the 6-bit sync 
option is selected while in the Bisync mode, this bit is 
ignored. 



When this bit is set to 1 , receiver operation begins. This bit 
should be set only after all other receiver parameters are 
established and the receiver is completely initialized. This 
bit is reset by a channel or hardware reset command, and 
it disables the receiver. 

5.2.5 Write Register 4 (Transmit/Receive 
Miscellaneous Parameters and Modes) 

WR4 contains the control bits for both the receiver and the 
transmitter. These bits should be set in the transmit and 
receiver initialization routine before issuing the contents of 
WR1, WR3, WR6, and WR7. Bit positions for WR4 are 
shown in Figure 5-6. On the ESCC, with the Extended Read 
option enabled, this register is read as RR4. 



Write Register 4 



| D7 1 D6 1 D5 D4 1 D3 1 D2 1 D1 1 DO | 



Parity Enable 
Parity EVEN//ODD 



Sync Modes Enable 

1 1 Stop Bit/Character 

1 1 1/2 Stop Bits/Character 
1 1 2 Stop Bits/Character 



8-Bit Sync Character 

1 16-Bit Sync Character 

1 SDLC Mode (01111110 Flag) 
1 1 External Sync Mode 



The address recognition logic of the receiver is modified in 
SDLC mode if this bit is set to 1, i.e., only the four most 
significant bits of WR6 must match the receiver address. 
This procedure allows the SCC to receive frames from up 
to 16 separate sources without programming WR6 for 



X1 Clock Mode 
X1 6 Clock Mode 
X32 Clock Mode 
X64 Clock Mode 



Figure 5-6. Write Register 4 
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Bits 7 and 6: Clock Rate bits 1 and 0. 

These bits specify the multiplier between the clock and 
data rates. In synchronous modes, the 1X mode is forced 
internally and these bits are ignored unless External Sync 
mode has been selected. 

1X Mode (00). The clock rate and data rate are the same. 
In External Sync mode, this bit combination specifies that 
only the /SYNC pin is used to achieve character synchro- 
nization. 

16X Mode (01). The clock rate is 16 times the data rate. In 
External Sync mode, this bit combination specifies that 
only the /SYNC pin is used to achieve character synchro- 
nization. 

32X Mode (10). The clock rate is 32 times the data rate. In 
External Sync mode, this bit combination specifies that 
either the /SYNC pin or a match with the character stored 
in WR7 will signal character synchronization. The sync 
character can be either six or eight bits long as specified 
by the 6-bit/8-bit sync bit in WR10. 

64X Mode (11). The clock rate is 64 times the data rate. 
With this bit combination in External Sync mode, both the 
receiver and transmitter are placed in SDLC mode. The 
only variation from normal SDLC operation is that the 
/SYNC pin is used to start or stop the reception of a frame 
by forcing the receiver to act as though a flag had been 
received. 

Bits 5 and 4: SYNC Mode selection bits 1 and 0. 

These two bits select the various options for character 
synchronization. They are ignored unless synchronous 
modes are selected in the stop bits field of this register. 

Monosync Mode (00). In this mode, the receiver achieves 
character synchronization by matching the character stored 
in WR7 with an identical character in the received data 
stream. The transmitter uses the character stored in WR6 
as a time fill. The sync character is either six or eight bits, 
depending on the state of the 6-bit/8-bit sync bit in WR10. 
If the Sync Character Load Inhibit bit is set, the receiver 
strips the contents of WR6 from the data stream if received 
within character boundaries. 

Bisync Mode (01). The concatenation of WR7 with WR6 is 
used for receiver synchronization and as a time fill by the 
transmitter. The sync character is 12 or 16 bits in the 
receiver, depending on the state of the 6-bit/8-bit sync bit 
in WR10. The transmitted character is always 16 bits. 



SDLC Mode (10). In this mode, SDLC is selected and 
requires a Flag (01111110) to be written to WR7. The 
receiver address field is written to WR6. The SDLC CRC 
polynomial is also selected (WR5) in SDLC mode. 

External Sync Mode (11). In this mode, the SCC expects 
external logic to signal character synchronization via the 
/SYNC pin. If the crystal oscillator option is selected (in 
WR11), the internal /SYNC signal is forced to 0. In this 
mode, the transmitter is in Monosync mode using the 
contents of WR6 as the time fill with the sync character 
length specified by the 6-bit/8-bit Sync bit in WR10. 

Bits 3 and 2: Stop Bits selection, bits 1 and 0. 

These bits determine the number of stop bits added to 
each asynchronous character that is transmitted. The 
receiver always checks for one stop bit in Asynchronous 
mode. A special mode specifies that a Synchronous mode 
is to be selected. D2 is always set to 1 by a channel or 
hardware reset to ensure that the /SYNC pin is in a known 
state after a reset. 

Synchronous Modes Enable (00). This bit combination 
selects one of the synchronous modes specified by bits 
D4, D5, D6, and D7 of this register and forces the 1X Clock 
mode internally. 

1 Stop Bit/Character (01). This bit selects Asynchronous 
mode with one stop bit per character. 

11/2 Stop Bits/Character (1 0). These bits select Asynchro- 
nous mode with 1-1/2 stop bits per character. This mode 
is not used with the 1X clock mode. 

2 Stop Bits/Character (1 1 ). These bits select Asynchro- 
nous mode with two stop bits per transmitted character 
and checks for one received stop bit. 

Bit 1: Parity Even//Odd select bit. 

This bit determines whether parity is checked as even or 
odd. A 1 programmed here selects even parity, and a 
selects odd parity. This bit is ignored if the Parity enable bit 
is not set. 

BitO: Parity Enable. 

When this bit is set, an additional bit position beyond those 
specified in the bits/character control is added to the 
transmitted data and is expected in the receive data. The 
Received Parity bit is transferred to the CPU as part of the 
data unless eight bits per character is selected in the 
receiver. 
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5.2.6 Write Register 5 (Transmit Parameters 
and Controls) 

WR5 contains control bits that affect the operation of the 
transmitter. D2 affects both the transmitter and the re- 
ceiver. Bit positions for WR5 are shown in Figure 5-7. With 
the Extended Read option enabled, this register is read 
as RR5. 

Write Registers 

D7| D6| D5| D4| D3| D2| D1 [do] 

I — — TxCRC Enable 

l— RTS 

L /SDLC/CRC-16 

' Tx Enable 

' Send Break 

Tx 5 Blts(Or Less)/Character 

1 Tx 7 Bits/Character 

1 Tx 6 Bits/Character 
1 1 Tx 8 Bits/Character 

DTR 



Figure 5-7. Write Register 5 



Bit 7: Data Terminal Ready control bit. 

This is the control bit for the /DTR//REQ pin while the pin is 
in the DTR mode (selected in WR14). When set, /DTR is 
Low; when reset, /DTR is High. This bit is ignored when 
/DTR//REQ is programmed to act as a/REQ pin. This bit is 
reset by a channel or hardware reset. 

Bits 6 and 5: Transmit Bits/Character select bits 1 and 0. 

These bits control the number of bits in each byte trans- 
ferred to the transmit buffer. Bits sent must be right justified 
with the least significant bits first. 

The Five Or Less mode allows transmission of one to five 
bits per character. For five or fewer bits per character, the 
data character must be formatted as shown below in Table 
5-5. In the Six or Seven Bits/Character modes, unused 
data bits are ignored. 

Bit 4: Send Break control bit. 

When set, this bit forces the TxD output to send continuous 
0s beginning with the following transmit clock, regardless 
of any data being transmitted at the time. This bit functions 
whether or not the transmitter is enabled. When reset, TxD 
continues to send the contents of the Transmit Shift regis- 
ter, which might be syncs, data, or all 1s. If this bit is set 



while in the X21 mode (Monosync and Loop mode se- 
lected) and character synchronization is achieved in the 
receiver, this bit is automatically reset and the transmitter 
begins sending syncs or data. This bit is also reset by a 
channel or hardware reset. 



Table 5-5. Transmit Bits per Character 



Bit 7 


Bit 6 










5 or less bits / character 





1 


7 bits / character 


1 





6 bits / character 


1 


1 


8 bits / character 



Note: 

For five or less bits per character selection in WR5, the following encoding 
is used in the data sent to the transmitter. D is the data bit(s) to be sent. 



D7 D6 D5 D4 D3 D2 D1 DO 



1 


1 


1 


1 











D 


Sends one data bit 


1 


1 


1 











D 


D 


Sends two data bits 


1 


1 











D 


D 


D 


Sends three data bits 


1 











D 


D 


D 


D 


Sends four data bits 











D 


D 


D 


D 


D 


Sends five data bits 



Bit 3: Transmit Enable. 



Data is not transmitted until this bit is set, and the TxD 
output sends continuous 1s unless Auto Echo mode or 
SDLC Loop mode is selected. If this bit is reset after 
transmission starts, the transmission of data or sync char- 
acters is completed. If the transmitter is disabled during 
the transmission of a CRC character, sync or flag charac- 
ters are sent instead of CRC. This bit is reset by a channel 
or hardware reset. 

Bit 2: SDLC/CRC-16 polynomial select bit. 

This bit selects the CRC polynomial used by both the 
transmitter and receiver. When set, the CRC-1 6 polynomial 
is used; when reset, the SDLC polynomial is used. The 
SDLC/CRC polynomial is selected when SDLC mode is 
selected. The CRC generator and checker can be 
preset to all Os or all 1s, depending on the state of the 
Preset 1/Preset bit in WR10. 

Bit 1 : Request To Send control bit. 

This is the control bit for the /RTS pin. When the RTS bit is 
set, the /RTS pin goes Low; when reset, /RTS goes High. 
When Auto Enable is set in asynchronous mode, the /RTS 
pin immediately goes Low when the RTS bit is set. How- 
ever, when the RTS bit is reset, the /RTS pin remains Low 
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until the transmitter is completely empty and the last stop 
bit has left the TxD pin. In synchronous modes, the 
/RTS pin directly follows the state of this bit, except in SDLC 
mode under specific conditions. In SDLC mode, if Flag On 
Underrun bit (WR10, D2) is set, RTS bit in WR5 is reset, and 
D2 in WR7' is set. The /RTS pin deasserts automatically at 
the last bit of the closing flag triggered by the rising edge 
of the Tx clock. This bit is reset by a channel or hardware 
reset. 

Bit 0: Transmit CRC Enable. 

This bit determines whether or not the CRC is calculated on 
a transmit character. If this bit is set at the time the 
character is loaded from the transmit buffer to the Transmit 



Shift register, the CRC is calculated on that character. The 
CRC is not automatically sent unless this bit is set when the 
transmit underrun exists. 

5.2.7 Write Register 6 (Sync Characters or 
SDLC Address Field) 

WR6 is programmed to contain the transmit sync character 
in the Monosync mode, or the first byte of a 1 6-bit sync 
character in the External Sync mode. WR6 is not used in 
asynchronous modes. In the SDLC modes, it is pro- 
grammed to contain the secondary address field used to 
compare against the address field of the SDLC Frame. In 
SDLC mode, the SCC does not automatically transmit the 
station address at the beginning of a response frame. Bit 
positions for WR6 are shown in Figure 5-8. 



Write Register 6 

| D7 1 D6 1 D5 1 D4 1 D3 1 D2 1 D1 1 DO | 



Sync7 Sync6 Sync5 Sync4 

Synd SyncO Sync5 Sync4 

Sync7 Sync6 Sync5 Sync4 

Sync3 Sync2 Synd SyncO 

ADR7 ADR6 ADR5 ADR4 

ADR7 ADR6 ADR5 ADR4 



Sync3 Sync2 Synd SyncO Monosync, 8 Bits 

Sync3 Sync2 Synd SyncO Monosync, 6 Bits 

Sync3 Sync2 Synd SyncO Bisync, 16 Bits 

1 1 1 1 Bisync, 12 Bits 

ADR3 ADR2 ADR1 ADRO SDLC 

x x x x SDLC (Address Range) 



Figure 5-8. Write Register 6 



5.2.8 Write Register 7 (Sync Character or 
SDLC Flag) 

WR7 is programmed to contain the receive sync character 
in the Monosync mode, a second byte (the last eight bits) 
of a 16-bit sync character in the Bisync mode, or a Flag 



character (01 1 1 1 1 10) in the SDLC modes. WR7 holds the 
receive sync character or a flag if one of the special 
versions of the External Sync mode is selected. WR7 is not 
used in Asynchronous mode. Bit positions for WR7 are 
shown in Figure 5-9. 



Write Register 7 

| D7 1 D6 1 D5 1 D4 1 D3 1 D2 1 D1 1 DO | 



Sync7 Sync6 Sync5 Sync4 

Sync5 Sync4 Sync3 Sync2 

Synd 5 Synd 4 Sync13 Sync12 

Sync11 SyndO Sync9 Sync8 

1 1 1 



Sync3 
Synd 
Sync11 
Sync7 
1 



Sync2 Synd SyncO 
SyncO x x 

SyndO Sync9 

Sync6 Sync5 
1 1 



Monosync, 8 Bits 
Monosync, 6 Bits 
Sync8 Bisync, 16 Bits 
Sync4 Bisync, 12 Bits 
SDLC 



Figure 5-9. Write Register 7 
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5.2.9 Write Register 7 Prime (ESCC only) 



Bit 4: /DTR//REQ Timing. 



This Register is used only with the ESCC. 
Write Register 7 Prime is located at the same address as 
Write Register 7. This register is written to by setting bit DO 
of WR15 to a 1 . Refer to the description in the section on 
Write Register 15. Features enabled in WR7 Prime remain 
enabled unless otherwise disabled; a hardware or channel 
reset leaves WR7 Prime with all features intact (register 
contents are 0) (Figure 5-10). 

WR 7' Prime _ 

D7| D6 1 D5| D4| D3 1 D2I D1 I Dol 



1 Auto Tx Rag 

I Auto EOM Reset 

* Auto /RTS Deactivation 

■ Rx FIFO Int Level 

I /DTR//REQ Timing Mode 

■ — Tx FIFO Int Level 

--— --— — — — Extended Read Enable 
— ■— — — — — ~— — — Not Used, Always 

Figure 5-10. Write Register 7 Prime 



Bit 7: Reserved. This bit is not used and must always be 
written zero. 

Bit 6: Extended Read Enable bit. 

Setting this bit enables the reading of WR3, WR4, WR5, 
WR7 Prime and WR1 0. When this feature is enabled, these 
registers can be accessed by reading RR9, RR4, RR5, 
RR14, and RR1 1 , respectively. When the extended read is 
not enabled, register access is identical to that of the 
NMOS/CMOS version. Refer to Chapter Two on how this 
feature affects the mapping of read registers. 

Bit 5: Transmit FIFO Interrupt Level. 

If this bit is set, the transmit buffer empty interrupt is 
generated when the Transmit FIFO is completely empty. If 
this bit is reset (0), the transmit buffer empty interrupt is 
generated when the entry location of the Transmit FIFO is 
empty. This latter operation is identical to that of the NMOS/ 
CMOS version. 

In the DMA Request on Transmit Mode, when using either 
the /W//REQ or /DTR//REQ pins, the request is asserted 
when the Transmit FIFO is completely empty if the Transmit 
FIFO Interrupt Level bit is set. The request is asserted when 
the entry location of the Transmit FIFO is empty if the 
Transmit FIFO Interrupt Level bit is reset (0). 



If this bit is set and the /DTR//REQ pin is used for Request 
Mode (WR14 bit D2 = 1 ), the deactivation of the /DTR//REQ 
pin is identical to the /W//REQ pin. Refer to the chapter on 
interfacing for further details. If this bit is reset (0), the 
deactivation time for the /DTR//REQ pin is 4TcPc. This 
latter operation is identical to that of the SCC. 

Bit 3: Receive FIFO Interrupt Level. 

lfWR7' D3=1 and "Receive Interrupt on All Characters and 
Special Conditions" is enabled, the Receive Character 
Available interrupt is triggered when the Rx FIFO is half full, 
i.e., the four byte slots of the Rx FIFO are empty. However, 
if any character has a special condition, a special condi- 
tion interrupt is generated when the character is loaded 
into the Receive FIFO. Therefore, the special condition 
interrupt service routine should read RR1 before reading 
the data to determine which byte has which special 
condition. 

If WR7' D3=0, the ESCC sets the receiver and generates 
the receive character available interrupt on every received 
character, regardless of any special receive condition. 

Bit 2: Auto /RTS pin Deactivation. 

This bit controls the timing of the deassertion of the /RTS 
pin. If the ESCC is programmed for SDLC mode and Flag- 
On-Underrun (WR10 D2=0), this bit is set and the RTS bit 
is reset. The /RTS is deasserted automatically at the last bit 
of the closing flag, triggered by the rising edge of the 
Transmit Clock. If this bit is reset, the /RTS pin follows the 
state programmed in WR5 D1 . 

Bit 1: Automatic EOM Reset. 

If this bit is set, the ESCC automatically resets the Tx 
Underrun/EOM latch and presets the transmit CRC gen- 
erator to its programmed preset state (per values set in 
WR5 D2 & WR 1 D7). Therefore, it is not necessary to issue 
the Reset Tx Underrun/EOM latch command when this 
feature is enabled. If this bit is reset, ESCC operation is 
identical to the SCC. 

Bit 0: Automatic Tx SDLC Flag. 

If this bit is set, the ESCC automatically transmits an SDLC 
flag before transmitting data. This removes the requirement 
to reset the mark idle bit (WR10 D3) before writing data to 
the transmitter, or having to enable the transmitter before 
writing data to the Transmit FIFO. Also, this feature enables 
a transmit data write before enabling the transmitter. If this 
bit is reset, operation is identical to that of the SCC. 
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5.2.10 Write Register 8 (Transmit Buffer) 

WR8 is the transmit buffer register. 

5.2.1 1 Write Register 9 (Master Interrupt 
Control) 

WR9 is the Master Interrupt Control register and contains 
the Reset command bits. Only one WR9 exists in the SCC 
and is accessed from either channel. The Interrupt control 
bits are programmed at the same time as the Reset 
command, because these bits are only reset by a hard- 
ware reset. Bit positions for WR9 are shown in Figure 5-11. 



Force Hardware Reset Command (11). The effects of this 
command are identical to those of a hardware reset, 
except that the Shift Right/Shift Left bit is not changed and 
the MIE, Status High/Status Low and DLC bits take the 
programmed values that accompany this command. 

Bit 5: Software Interrupt Acknowledge control bit. 

If bit D5 is set, reading Read Register 2 (RR2) results in an 
interrupt acknowledge cycle to be executed internally. 
Like a hardware INTACK cycle, a software acknowledge 
causes the INT pin to return High, the IEO pin to go Low, 
and sets the IUS latch for the highest priority interrupt 
pending. 



Write Register 9 



|"d7 D6| D5 D4| D3| D2 D1 1 Do| 



VIS 
NV 
DLC 
MIE 

Status Hlgh//Status Low 

Software INTACK Enable 
(Reserved on NMOS) 



No Reset 

1 Channel Reset B 

1 Channel Reset A 

1 1 Force Hardware Reset 



Figure 5-11. Write Register 9 



Bit 7 and 6: Reset Command Bits. 

Together, these bits select one of the reset commands for 
the SCC. Setting either of these bits to 1 disables both the 
receiver and the transmitter in the corresponding channel; 
forces TxD for that channel marking, forces the modem 
control signals High in that channel, resets all IPs and lUSs 
and disables all interrupts in that channel. Four extra PCLK 
cycles must be allowed beyond the usual cycle time after 
any of the reset commands is issued before any additional 
commands or controls are written to the channel affected. 

Null Command (00). This command has no effect. It is used 
when a write to WR9 is necessary for some reason other 
than an SCC Reset command. 



This bit is reserved on NMOS, and always writes as 0. 

Bit 4: Status High//Status Low control bit. 

This bit controls which vector bits the SCC modifies to 
indicate status. When set to 1 , the SCC modifies bits V6, 
V5, and V4 according to Table 5-6. When set to 0, the SCC 
modifies bits V1 , V2, and V3. This bit controls status in both 
the vector returned during an interrupt acknowledge cycle 
and the status in RR2B. This bit is reset by a hardware 
reset. 



Table 5-6. Interrupt Vector Modification 


V3 


V2 


V1 


Status High/Status Low =0 


V4 


V5 


V6 


Status High/Status Low =1 











Ch B Transmit Buffer Empty 








1 


Ch B External/Status Change 





1 





Ch B Receive Char. Available 





1 


1 


Ch B Special Receive Condition 


1 








Ch A Transmit Buffer Empty 


1 





1 


Ch A External/Status Change 


1 


1 





Ch A Receive Char. Available 


1 


1 


1 


Ch A Special Receive Condition 



Bit 3: Master Interrupt Enable. 

This bit is set to 1 to globally enable interrupts, and cleared 
to zero to disable interrupts. Clearing this bit to zero forces 
the IEO pin to follow the state of the IEI pin unless there is 
an IUS bit set in the SCC. No IUS bit is set after the MIE bit 
is cleared to zero. This bit is reset by a hardware reset. 



Channel Reset B Command (01). Issuing this command 
causes a channel reset to be performed on Channel B. 

Channel Reset A Command (10). Issuing this command 
causes a channel reset to be performed on Channel A. 



Bit 2: Disable Lower Chain control bit. 

The Disable Lower Chain bit is used by the CPU to control 
the interrupt daisy chain. Setting this bit to 1 forces the IEO 
pin Low, preventing lower priority devices on the daisy 
chain from requesting interrupts. This bit is reset by a 
hardware reset. 
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Bit 1 : No Vector select bit. 



Bit 7: CRC Presets I/O select bit. 



The No Vector bit controls whether or not the SCC re- 
sponds to an interrupt acknowledge cycle. This is done by 
placing a vector on the data bus if the SCC is the highest 
priority device requesting an interrupt. If this bit is set, no 
vector is returned; i.e., AD7-AD0 remains tri-stated during 
an interrupt acknowledge cycle, even if the SCC is the 
highest priority device requesting an interrupt. 

Bit 0: Vector Includes Status control bit. 

The Vector Includes Status Bit controls whether or not the 
SCC includes status information in the vector it places on 
the bus in response to an interrupt acknowledge cycle. If 
this bit is set, the vector returned is variable, with the 
variable field depending on the highest priority IP that is 
set. Table 5-5 shows the encoding of the status informa- 
tion. This bit is ignored if the No Vector (NV) bit is set. 

5.2.12 Write Register 10 (Miscellaneous 
Transmitter/Receiver Control Bits) 

WR10 contains miscellaneous control bits for both the 
receiver and the transmitter. Bit positions for WR10 are 
shown in Figure 5-12. On the ESCC with the Extended 
Read option enabled, this register may be read as RR1 1. 

Write Register 10 



D7 D6 D5 D4 D3 D2 D1 



NRZ 

1 NRZI 

1 FM1 (Transition = 1) 
1 1 FMO (Transition = 0) 



6-Bit//8-Bit Sync 
Loop Mode 

AbonV/Flag On Underrun 
Mark//Flag Idle 
Go Active On Poll 



CRC Preset I//0 



This bit specifies the initialized condition of the receive 
CRC checker and the transmit CRC generator. If this bit is 
set to 1 , the CRC generator and checker are preset to 1 . If 
this bit is set to 0, the CRC generator and checker are 
preset to 0. Either option can be selected with either CRC 
polynomial. In SDLC mode, the transmitted CRC is inverted 
before transmission, and the received CRC is checked 
against the bit pattern 0001 1 101 00001 1 1 1 . This bit is reset 
by a channel or hardware reset. This bit is ignored in 
Asynchronous mode. 

Bits 6 and 5: Data Encoding select bits. 

These bits control the coding method used for both the 
transmitter and the receiver, as illustrated in Table 5-7. 
All of the clocking options are available for all coding 
methods. The DPLL in the SCC is useful for recovering 
clocking information in NRZI and FM modes. Any coding 
method can be used in X1 mode. A hardware reset forces 
NRZ mode. Timing for the various modes is shown in 
Figure 5-13. 

Table 5-7. Data Encoding 



Bit 6 


Bit 5 


Encoding 








NRZ 





1 


NRZI 


1 





FM1 (transition = 1) 


1 


1 


FMO (transition = 0) 



Figure 5-12. Write Register 10 
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Data 



NRZ 



NRZI 



FM1 



FMO 



\ 

\ f 




j v 
v 



Manchester 



r^/ \ r 



Figure 5-13. NRZ (NRZI), FM1 (FMO) Timing 



Bit 4: Go-Active-On-Poll control bit. 

When Loop mode is first selected during SDLC operation, 
the SCC connects RxD to TxD with only gate delays in the 
path. The SCC does not go on-loop and insert the 1-bit 
delay between RxD and TxD until this bit has been set and 
an EOP received. When the SCC is on-loop, the transmitter 
does not go active unless this bit is set at the time an EOP 
is received. The SCC examines this bit whenever the 
transmitter is active in SDLC Loop mode and is sending a 
flag. If this bit is set at the time the flag is leaving the 
Transmit Shift register, another flag or data byte (if the 
transmit buffer is full) is transmitted. 

If the Go-Active-On-Poll bit is not set at this time, the 
transmitter finishes sending the flag and reverts to the 1 -Bit 
Delay mode. Thus, to transmit only one response frame, 
this bit is reset after the first data byte is sent to the SCC, 
but before CRC has been transmitted. If the bit is not reset 
before CRC is transmitted, extra flags are sent, slowing 
down response time on the loop. If this bit is reset before 
the first data is written, the SCC completes the transmis- 
sion of the present flag and reverts to the 1 -Bit Delay mode. 

After gaining control of the loop, the SCC is not able to 
transmit again until a flag and another EOP are received. 
It is good practice to set this bit only upon receipt of a poll 
frame to ensure that the SCC does not go on-loop without 
the CPU noticing it. 



In synchronous modes other than SDLC with the Loop 
Mode bit set, this bit is set before the transmitter goes 
active in response to a received sync character. 

This bit is always ignored in Asynchronous mode and 
Synchronous modes unless the Loop Mode bit is set. This 
bit is reset by a channel or hardware reset. 

Bit 3: Mark//Flag Idle line control bit. 

This bit affects only SDLC operation and is used to control 
the idle line condition. If this bit is set to 0, the transmitter 
send flags as an idle line. If this bit is setto 1 , the transmitter 
sends continuous 1 s after the closing flag of a frame. The 
idle line condition is selected byte by byte i.e., either a flag 
or eight 1 s are transmitted. The primary station in an SDLC 
loop should be programmed for Mark Idle to create the 
EOP sequence. Mark Idle must be deselected at the 
beginning of a frame before the first data is written to the 
SCC, so that an opening flag is transmitted. This bit is 
ignored in Loop mode, but the programmed value takes 
effect upon exiting the Loop mode. This bit is reset by a 
channel or hardware reset. 

On the ESCC with the Automatic TX SDLC Flag mode 
enabled (WR7\ D0=1), this bit can be left as mark idle. It 
will send an opening flag automatically, as well as sending 
a closing flag followed by mark idle after the frame trans- 
mission is completed. 
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Bit 2: Abort//Flag On Underrun select bit. 



Bit 0: 6-Bit/8-Bit SYNC select bit. 



This bit affects only SDLC operation and is used to control 
how the SCC responds to a transmit underrun condition. If 
this bit is set to 1 and a transmit underrun occurs, the SCC 
sends an abort and a flag instead of a CRC. If this bit is 
reset, the SCC sends a CRC on a transmit underrun. At the 
beginning of this 16-bit transmission, the Transmit Underrun/ 
EOM bit is set, causing an External/Status interrupt. The 
CPU uses this status, along with the byte count from 
memory or the DMA, to determine whether the frame must 
be retransmitted. 

To start the next frame, a Transmit Buffer Empty interrupt 
occurs at the end of this 1 6-bit transmission. If both this bit 
and the Mark/Flag Idle bit are set to 1 , all 1 s are transmitted 
after the transmit underrun. This bit should be set after the 
first byte of data is sent to the SCC and reset immediately 
after the last byte of data, terminating the frame properly 
with CRC and a flag. This bit is ignored in Loop mode, but 
the programmed value is active upon exiting Loop mode. 
This bit is reset by a channel or hardware reset. 

Bit 1 : Loop Mode control bit. 

In SDLC mode, the initial set condition of this bit forces the 
SCC to connect TxD to RxD and to begin searching the 
incoming data stream so that it can go on loop. All bits 
pertinent to SDLC mode operation in other registers are set 
before this mode is selected. The transmitter and receiver 
are not enabled until after this mode has been selected. As 
soon as the Go-Active-On-Poll bit is set and an EOP is 
received, the SCC goes on-loop. If this bit is reset after the 
SCC goes on-loop , the SCC waits for the next EOP to go off- 
loop. 

In synchronous modes, the SCC uses this bit, along with 
the Go-Active-On-Poll bit, to synchronize the transmitter to 
the receiver. The receiver should not be enabled until after 
this mode is selected. The TxD pin is held marking when 
this mode is selected unless a break condition is pro- 
grammed. The receiver waits for a sync character to be 
received and then enables the transmitter on a character 
boundary. The break condition, if programmed, is re- 
moved. This mode works properly with sync characters of 
6, 8, or 16 bits. This bit is ignored in Asynchronous mode 
and is reset by a channel or hardware reset. 



This bit is used to select a special case of synchronous 
modes. If this bit is set to 1 in Monosync mode, the receiver 
and transmitter sync characters are six bits long instead of 
the usual eight. If this bit is set to 1 in Bisync mode, the 
received sync is 1 2 bits and the transmitter sync character 
remains 16 bits long. This bit is ignored in SDLC and 
Asynchronous modes, but still has effect in the special 
external sync modes. This bit is reset by a channel or 
hardware reset. 

5.2.13 Write Register 1 1 (Clock Mode Control) 

WR1 1 is the Clock Mode Control register. The bits in this 
register control the sources of both the receive and trans- 
mit clocks, the type of signal on the /SYNC and /RTxC pins, 
and the direction of the /TRxC pin. Bit positions for WR1 1 
are shown in Figure 5-14; also, refer to Section 3.5 Clock 
Selection. 

Write Register 11 

| D7 1 D6| D5| D4 1 D3| D2| D1 1 Do] 



I I 



/TRxC Out = Xtal Output 
/TRxC Out = Transmit Clock 
/TRxC Out = BR Generator Output 
/TRxC Out = DPLL Output 



/TRxC 0/I 



Transmit Clock = /RTxC Pin 

1 Transmit Clock = /TRxC Pin 

1 Transmit Clock = BR Generator Output 
1 1 Transmit Clock = DPLL Output 

Receive Clock = /RTxC Pin 
Receive Clock = /TRxC Pin 
Receive Clock = BR Generator Output 
Receive Clock = DPLL Output 



/RTxC Xtal//No Xtal 



Figure 5-14. Write Register 11 



Bit 7: RTxC-XTAL//NO XTAL select bit. 

This bit controls the type of input signal the SCC expects 
to see on the /RTxC pin. If this bit is set to 0, the SCC 
expects a TTL-compatible signal as an input to this pin. If 
this bit is set to 1 , the SCC connects a high-gain amplifier 
between the /RTxC and /SYNC pins in expectation of a 
quartz crystal being placed across the pins. 
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The output of this oscillator is available for use as a 
clocking source. In this mode of operation, the /SYNC pin 
is unavailable for other use. The /SYNC signal is forced to 
zero internally. A hardware resetforces/NO XTAL. (At least 
20 ms should be allowed after this bit is set to allow the 
oscillator to stabilize.) 

Bits 6 and 5: Receiver Clock select bits 1 and 0. 

These bits determine the source of the receive clock as 
shown in Table 5-8. They do not interfere with any of the 
modes of operation in the SCC, but simply control a 
multiplexer just before the internal receive clock input. A 
hardware reset forces the receive clock to come from the 
/RTxC pin. 

Table 5-8. Receive Clock Source 



Bit 6 Bit 5 Receive Clock 









/RTxC Pin 





1 


/TRxC Pin 


1 





BR Output 


1 


1 


DPLL Output 



Bits 4 and 3: Transmit Clock select bits 1 and 0. 



These bits determine the source of the transmit clock as 
shown in Table 5-9. They do not interfere with any of the 
modes of operation of the SCC, but simply control a 
multiplexer just before the internal transmit clock input. The 
DPLL output that is used to feed the transmitter in FM 
modes lags by 90 degrees the output of the DPLL used by 
the receiver. This makes the received and transmitted bit 
cells occur simultaneously, neglecting delays. A hardware 
reset selects the /TRxC pin as the source of the transmit 
clocks. 

Table 5-9. Transmit Clock Source 



Bit 4 Bit 3 Transmit Clock 









/RTxC Pin 





1 


/TRxC Pin 


1 





BR Output 


1 


1 


DPLL Output 



Bit 2 : TRxC Pin I/O control bit. 

This bit determines the direction of the /TRxC pin. If this bit 
is set to 1 , the /TRxC pin is an output and carries the signal 
selected by D1 and DO of this register. However, if either 
the receive or the transmit clock is programmed to come 
from the ATRxC pin, /TRxC is an input, regardless of the 
state of this bit. The /TRxC pin is also an input if this bit is 
set to 0. A hardware reset forces this bit to 0. 

Bits 1 and 0: /TRxC Output Source select bits 1 and 0. 

These bits determine the signal to be echoed out of the 
SCC via the /TRxC pin as given in Table 5-10. No signal is 
produced if /TRxC has been programmed as the source of 
either the receive or the transmit clock. If /TRxC O/l (bit 2) 
is set to 0, these bits are ignored. 

If the XTAL oscillator output is programmed to be echoed, 
and the XTAL oscillator is not enabled, the /TRxC pin goes 
High. The DPLL signal that is echoed is the DPLL signal 
used by the receiver. Hardware reset selects the XTAL 
oscillator as the output source. 



Table 5-10. Transmit External Control Selection 



Bit 1 


BitO 


TRxC Pin Output 








XTAL Oscillator Output 





1 


Transmit Clock 


1 





BR Output 


1 


1 


DPLL Output (receive) 



5.2.14 Write Register 12 (Lower Byte of Baud 
Rate Generator Time Constant) 

WR12 contains the lower byte of the time constant for the 
baud rate generator. The time constant can be changed at 
any time, but the new value does not take effect until the 
next time the time constant is loaded into the down counter. 
No attempt is made to synchronize the loading of the time 
constant into WR12 and WR13 with the clock driving the 
down counter. For this reason, it is advisable to disable the 
baud rate generator while the new time constant is loaded 
into WR12 and WR13. Ordinarily, this is done anyway to 
prevent a load of the down counter between the writing of 
the upper and lower bytes of the time constant. 



5-17 



The formula for determining the appropriate time constant 
for a given baud is shown below, with the desired rate in 
bits per second and the BR clock period in seconds. This 
formula is derived because the counter decrements from 
N down to zero-plus-one-cycle for reloading the time 
constant. This is then fed to a toggle flip-flop to make the 
output a square wave. Bit positions for WR1 2 are shown in 
Figure 5-15. 



Time 



Clock Frequency 



Constant 2 x ( Des j re ci Rate) x (BR Clock Period) 



Write Register 12 

| D7 1 D6| D5 1 D4| D3| D2 1 D1 1 DO | 



-2 



TC0^\ 
TC1 
TC2 
TC3 
TC4 
TC5 
TC6 
TC7 J 



> Lower Byte of 
Time Constant 



5.2.16 Write Register 14 (Miscellaneous 
Control Bits) 

WR1 4 contains some miscellaneous control bits. Bit posi- 
tions for WR14 are shown in Figure 5-17. For DPLL func- 
tion, refer to section 3.4 as well. 

Write Register 14 



| D7 1 D6 1 D5 1 D4 1 D3 1 D2 1 D1 | DO 



BR Generator Enable 
BR Generator Source 
/DTR/Request Function 
Auto Echo 
Local Loopback 



Null Command 

1 Enter Search Mode 

Reset Missing Clock 

1 Disable DPLL 

Set Source = BR Generator 

1 Set Source = /RTxC 

Set FM Mode 

1 Set NRZI Mode 



Figure 5-17. Write Register 14 



Bits D7-D5: Digital Phase-Locked Loop Command Bits. 



Figure 5-15. Write Register 12 



5.2.15 Write Register 13 (Upper Byte of Baud 
Rate Generator Time Constant) 

WR13 contains the upper byte of the time constant for the 
baud rate generator. Bit positions for WR13 are shown in 
Figure 5-1 6. 



Write Register 13 



EE 



D6 1 D5 D4 1 D3 1 D2 1 D1 I DO 



TC8 ^ 
TC9 
TC10 
TC11 
TC12 
TC13 
TC14 
TC15 



> Upper Byte of 
Time Constant 



Figure 5-16. Write Register 13 



These three bits encode the eight commands for the 
Digital Phase-Locked Loop. A channel or hardware reset 
disables the DPLL, resets the missing clock latches, sets 
the source to the /RTxC pin and selects NRZI mode. The 
Enter Search Mode command enables the DPLL after a 
reset. 

Null Command (000). This command has no effect on the 
DPLL. 

Enter Search Mode Command (001). Issuing this com- 
mand causes the DPLL to enter the Search mode, where 
the DPLL searches for a locking edge in the incoming data 
stream. The action taken by the DPLL upon receipt of this 
command depends on the operating mode of the DPLL. 

In NRZI mode, the output of the DPLL is High while the 
DPLL is waiting for an edge in the incoming data stream. 
After the Search mode is entered, the first edge the DPLL 
sees is assumed to be a valid data edge, and the DPLL 
begins the clock recovery operation from that point. The 
DPLL clock rate must be 32x the data rate in NRZI mode. 
Upon leaving the Search mode, the first sampling edge of 
the DPLL occurs 1 6 of these 32x clocks after the first data 
edge, and the second sampling occurs 48 of these 32x 
clocks after the first data edge. Beyond this point, the DPLL 
begins normal operation, adjusting the output to remain in 
sync with the incoming data. 
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In FM mode, the output of the DPLL is Low while the DPLL 
is waiting for an edge in the incoming data stream. The first 
edge the DPLL detects is assumed to be a valid clock 
edge. For this to be the case, the line must contain only 
clock edges; i.e. with FM1 encoding, the line must be 
continuous Os. With FMO encoding the line must be con- 
tinuous 1s, whereas Manchester encoding requires alter- 
nating 1 s and Os on the line. The DPLL clock rate must be 
16 times the data rate in FM mode. The DPLL output 
causes the receiver to sample the data stream in the 
nominal center of the two halves of the bit to decide 
whether the data was a 1 or a 0. 

After this command is issued, as in NRZI mode, the DPLL 
starts sampling immediately after the first edge is de- 
tected. (In FM mode, the DPLL examines the clock edge of 
every other bit to decide what correction must be made to 
remain in sync.) If the DPLL does not see an edge during 
the expected window, the one clock missing bit in RR10 is 
set. If the DPLL does not see an edge after two successive 
attempts, the two clocks missing bits in RR10 are set and 
the DPLL automatically enters the Search mode. This 
command resets both clocks missing latches. 

Reset Clock Missing Command (010). Issuing this com- 
mand disables the DPLL, resets the clock missing latches 
in RR10, and forces a continuous Search mode state. 

Disable DPLL Command (011). Issuing this command 
disables the DPLL, resets the clock missing latches in 
RR10, and forces a continuous Search mode state. 

Set Source to BRG Command (100). Issuing this com- 
mand forces the clock for the DPLL to come from the output 
of the BRG. 

Set Source to /RTxC Command (101). Issuing the com- 
mand forces the clock for the DPLL to come from the /RTxC 
pin or the crystal oscillator, depending on the state of the 
XTAL/no XTAL bit in WR1 1 . This mode is selected by a 
channel or hardware reset. 

Set FM Mode Command (110). This command forces the 
DPLL to operate in the FM mode and is used to recover the 
clock from FM or Manchester-Encoded data. (Manchester 
is decoded by placing the receiver in NRZ mode while the 
DPLL is in FM mode.) 

Set NRZI Mode Command (111). Issuing this command 
forces the DPLL to operate in the NRZI mode. This mode 
is also selected by a hardware or channel reset. 



Bit 4: Local Loopback select bit. 

Setting this bit to 1 selects the Local Loopback mode of 
operation. In this mode, the internal transmitted data is 
routed back to the receiver, and to the TxD pin. The /CTS 
and /DCD inputs are ignored as enables in Local Loopback 
mode, even if auto enable is selected. (If so programmed, 
transitions on these inputs still cause interrupts.) This 
mode works with any Transmit/Receive mode except Loop 
mode. For meaningful results, the frequency of the transmit 
and receive clocks must be the same. This bit is reset by 
a channel or hardware reset. 

Bit 3: Auto Echo select bit. 

Setting this bit to 1 selects the Auto Echo mode of opera- 
tion. In this mode, the TxD pin is connected to RxD as in 
Local Loopback mode, but the receiver still listens to the 
RxD input. Transmitted data is never seen inside or outside 
the SCC in this mode, and /CTS is ignored as a transmit 
enable. This bit is reset by a channel or hardware reset. 

Bit 2: DTR/Request Function select bit. 

This bit selects the function of the /DTR//REQ pin following 
the state of the DTR bit in WR5. If this is set to 0, the 
/DTR//REQ pin follows the state of the DTR bit in WR5. If this 
bit is set to 1 , the /DTR//REQ pin goes Low whenever the 
transmit buffer becomes empty and in any of the syn- 
chronous modes when the CRC has been sent at the end 
of a message. The request function on the /DTR//REQ pin 
differs from the transmit request function available on the 
/W//REQ pin. The /REQ does not go inactive until the 
internal operation satisfying the request is complete, which 
occurs three to four PCLK cycles after the falling edge of 
/DS, /RD or /WR. If the DMA used is edge-triggered, this 
difference is unimportant. The deassertion timing of the 
REQ mode can be programmed to occur with the same 
timing as the /W/REQ pin if WR7' D4=1 . This bit is reset by 
a channel or hardware reset. 

Bit 1 : Baud Rate Generator Source select bit. 

This bit selects the source of the clock for the baud rate 
generator, If this bit is set to 0. The baud rate generator 
clock comes from either the /RTxC pin or the XTAL oscil- 
lator (depending on the state of the XTAL//no XTAL bit). If 
this bit is set to 1 , the clock for the baud rate generator is 
the SCC's PCLK input. Hardware reset sets this bit to 0, 
select the /RTxC pin as the clock source for the BRG. 
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Bit 0: Baud Rate Generator Enable. 

This bit controls the operation of the BRG. The counter in 
the BRG is enabled for counting when this bit is set to 1 , 
and counting is inhibited when this bit is set to 0. When this 
bit is set to 1 . change in the state of this bit is not reflected 
by the output of the BRG for two counts of the counter. This 
allows the command to be synchronized. However, when 
set to 0, disabling is immediate. This bit is reset by a 
hardware reset. 

5.2.17 Write Register 1 5 (External/Status 
Interrupt Control) 

WR15 is the External/Status Source Control register. If the 
External/Status interrupts are enabled as a group via WR1 , 
bits in this register control which External/Status condi- 
tions cause an interrupt. Only the External/Status condi- 
tions that occur after the controlling bit is set to 1 cause an 
interrupt. This is true, even if an External/Status condition 
is pending at the time the bit is set. Bit positions for WR15 
are shown in Figure 5-18. 

On the CMOS version , bits D2 and DO are reserved . On the 
NMOS version, bit D2 is reserved. These reserved bits 
should be written as 0s. 



Write Register 15 

D7| D6| D5| D4| D3| D2| D1 1 Dp| 

WR7' SDLC Feature Enable 
(Reserved on NMOS/CMOS) 

' Zero Count IE 

' SDLC FIFO Enable (Reserved on NMOS) 

I DCD IE 

' Sync/Hunt IE 

' — CTSIE 

■ Tx Underrun/EOM IE 

— — • — — — — Break/Abort IE 



Figure 5-18. Write Register 15 



Bit 7: Break/Abort Interrupt Enable. 

If this bit is set to 1 , a change in the Break/Abort status of 
the receiver causes an External/Status interrupt. This bit is 
set by a channel or hardware reset. 

Bit 6: Transmit Underrun/EOM Interrupt Enable. 

If this bit is set to 1 , a change of state by the Tx Underrun/ 
EOM latch in the transmitter causes an External/Status 
interrupt. This bit is set to 1 by a channel or hardware reset. 



Bit 5: CTS Interrupt Enable. 

If this bit is set to 1, a change of state on the /CTS pin 
causes an External/Status Interrupt. This bit is set by a 
channel or hardware reset. 

Bit 4: SYNC/Hunt Interrupt Enable. 

If this bit is set to 1, a change of state on the /SYNC pin 
causes an External/Status interrupt in Asynchronous mode, 
and a change of state in the Hunt bit in the receiver causes 
and External/Status interrupt in synchronous modes. This 
bit is set by a channel or hardware reset. 

Bit 3: DCD Interrupt Enable. 

If this bit is set to 1 , a change of state on the /DCD pin 
causes an External/Status interrupt. This bit is set by a 
channel or hardware reset. 

Bit 2: Status FIFO Enable control bit (CMOS/ESCC). 

If this bit is set and if the CMOS/ESCC is in the SDLC/HDLC 
Mode, status (five bits from Read Register 1: Residue, 
Overrun, and CRC Error) and fourteen bits of byte count 
are held in the Status FIFO until read. Status information for 
up to ten frames can be stored. If this bit is reset (0) or if the 
CMOS/ESCC is not in the SDLC/HDLC Mode, the FIFO is 
not operational and status information read reflects the 
current status only. This bit is reset to by a channel or 
hardware reset. For details on this function, refer to 
Section 4.4.3. 

On the NMOS version, this bit is reserved and should be 
programmed as 0. 

Bit 1 : Zero Count Interrupt Enable. 

If this bit is set to 1, an External/Status interrupt is gener- 
ated whenever the counter in the baud rate generator 
reaches 0. This bit is reset to by a channel or hardware 
reset. 

Bit 0: Point to Write Register WR7 Prime (ESCG only). 

When this bit is programmed to 0, writes to the WR7 
address are made to WR7. When this bit is programmed to 
1 , writes to the WR7 address are made to WR7 Prime . Once 
set, this bit remains set unless cleared by writing a to this 
bit or by a hardware or software reset. Note that if the 
extended read option is enabled, WR7 Prime is read in 
RR14. For details about WR7', refer to Section 4.4.1 .2 and 
Section 5.2.9. 

On the NMOS/CMOS version, this bit is reserved and 
should be programmed as 0. 



5-20 



5.3 READ REGISTERS 



The SCC Read register set in each channel has four status 
registers (includes receive data FIFO), and two baud rate 
time constant registers in each channel.- The Interrupt 
Vector register (RR2) and Interrupt Pending register (RR3) 
are shared by both channels. In addition to these, the 
CMOS/ESCC has two additional registers for the SDLC 
Frame Status FIFO. On the ESCC, if that function is 
enabled (WR7' bit D6=1 ), five more registers are available 
which return the value written to the write registers. 

The status of these registers is continually changing and 
depends on the mode of communication, received and 
transmitted data, and the manner in which this data is 
transferred to and from the CPU. The following description 
details the bit assignment for each register. 

5.3.1 Read Register (Transmit/Receive 
Buffer Status and External Status) 

Read Register (RRO) contains the status of the receive 
and transmit buffers. RRO also contains the status bits for 
the six sources of External/Status interrupts. The bit con- 
figuration is illustrated in Figure 5-19. 

On the NMOS/CMOS version, note that the status of this 
register might be changing during the read. 

An enhancement allows the ESCC to latch the contents of 
RRO during read transactions for this register. The latch is 
released on the rising edge of the /RD of the read transac- 
tion to this register. This feature prevents missed status 
due to changes that take place when the read cycle is in 
progress. 



Read Register 

D7| D6 1 D5 1 D4| D3[ D2 1 Dl| Do| 

^ Rx Character Available 

■ Zero Count 

' Tx Buffer Empty 

' DCD 

' Sync/Hunt 

I CTS 

' Tx Underrun/EOM 

— —————— — — — — — i Break/Abort 

Figure 5-19. Read Register 



Bit 7: Break/Abort status. 

In the Asynchronous mode, this bit is set when a Break 
sequence (null character plus framing error) is detected in 
the receive data stream. This bit is reset when the se- 
quence is terminated, leaving a single null character in the 
Receive FIFO. This character is read and discarded. In 
SDLC mode, this bit is set by the detection of an Abort 
sequence (seven or more 1s), then reset automatically at 
the termination of the Abort sequence. In either case, if the 
Break/Abort IE bit is set, an External/Status interrupt is 
initiated. Unlike the remainder of the External/Status bits, 
both transitions are guaranteed to cause an External/ 
Status interrupt, even if another External/Status interrupt is 
pending at the time these transitions occur. This proce- 
dure is necessary because Abort or Break conditions may 
not persist. 

Bit 6: Transmit Underrun/EOM status. 

This bit is set by a channel or hardware reset when the 
transmitter is disabled or a Send Abort command is is- 
sued. This bit is only reset by the reset Tx Underrun/EOM 
Latch command in WRO. When the Transmit Underrun 
occurs, this bit is set and causes an External/Status inter- 
rupt (if the Tx Underrun/EOM IE bit is set). 

Only the 0-to-1 transition of this bit causes an interrupt. This 
bit is always 1 in Asynchronous mode, unless a reset Tx 
Underrun/EOM Latch command has been erroneously 
issued. In this case, the Send Abort command can be used 
to set the bit to one and at the same time cause an External/ 
Status interrupt. 

Bit 5: Clear to Send pin status. 

If the CTS IE bit in WR15 is set, this bit indicates the state 
of the /CTS pin while no interrupt is pending, latches the 
state of the /CTS pin and generates an External/Status 
interrupt. Any odd number of transitions on the /CTS pin 
causes another External/Status interrupt condition. If the 
CTS IE bit is reset, it merely reports the current unlatched 
state of the /CTS pin. 
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Bit 4: Sync/Hunt status. 

The operation of this bit is similar to that of the CTS bit, 
except that the condition monitored by the bit varies 
depending on the mode in which the SCC is operating. 

When the XTAL oscillator option is selected in asynchro- 
nous modes, this bit is forced to (no External/Status 
interrupt is generated). Selecting the XTAL oscillator in 
synchronous or SDLC modes has no effect on the opera- 
tion of this bit. 

The XTAL oscillator should not be selected in External 
Sync mode. 

In Asynchronous mode, the operation of this bit is identical 
to that of the CTS status bit, except that this bit reports the 
state of the /SYNC pin. 

In External sync mode the /SYNC pin is used by external 
logic to signal character synchronization. When the Enter 
Hunt Mode command is issued in External Sync mode, the 
/SYNC pin must be held High by the external sync logic 
until character synchronization is achieved. A High on the 
/SYNC pin holds the Sync/Hunt bit in the reset condition. 

When external synchronization is achieved, /SYNC is driven 
Low on the second rising edge of the Receive Clock after 
the last rising edge of the Receive Clock on which the last 
bit of the receive character was received. Once /SYNC is 
forced Low, it is good practice to keep it Low until the CPU 
informs the external sync logic that synchronization is lost 
or that a new message is about to start. Both transitions on 
the /SYNC pin cause External/Status interrupts if the 
Sync/Hunt IE bit is set to 1 . 

The Enter Hunt Mode command should be issued when- 
ever character synchronization is lost. At the same time, 
the CPU should inform the external logic that character 
synchronization has been lost and that the SCC is waiting 
for /SYNC to become active. 

In the Monosync and Bisync Receive modes, the Sync/ 
Hunt status bit is initially set to 1 by the Enter Hunt Mode 
command. The Sync/Hunt bit is reset when the SCC 
established character synchronization. Both transitions 
cause External/Status interrupts if the Sync/Hunt IE bit is 
set. When the CPU detects the end of message or the loss 
of character synchronization, the Enter Hunt Mode com- 
mand should be issued to set the Sync/Hunt bit and cause 
an External/Status interrupt. In this mode, the /SYNC pin is 
an output, which goes Low every time a sync pattern is 
detected in the data stream. 

In the SDLC modes, the Sync/Hunt bit is initially set by the 
Enter Hunt Mode command or when the receiver is disabled. 



It is reset when the opening flag of the first frame is 
detected by the SCC. An External/Status interrupt is also 
generated if the Sync/Hunt IE bit is set. Unlike the Monosync 
and Bisync modes, once the Sync/Hunt bit is reset in SDLC 
mode, it does not need to be set when the end of the frame 
is detected. The SCC automatically maintains synchroni- 
zation. The only way the Sync/Hunt bit is set again is by the 
Enter Hunt Mode command or by disabling the receiver. 

Bit 3: Data Carrier Detect status. 

If the DCD IE bit in WR15 is set, this bit indicates the state 
of the /DCD pin the last time the Enabled External/Status 
bits changed. Any transition on the /DCD pin, while no 
interrupt is pending, latches the state of the /DCD pin and 
generates an External/Status interrupt. Any odd number of 
transitions on the /DCD pin while another External/Status 
interrupt condition. If the DCD IE is reset, this bit merely 
reports the current, unlatched state of the /DCD pin. 

Bit 2: TX Buffer Empty status. 

This bit is set to 1 when the transmit buffer is empty. It is 
reset while the CRC is sent in a synchronous or SDLC 
mode and while the transmit buffer is full. The bit is reset 
when a character is loaded into the transmit buffer. 

On the ESCC, the status of this bit is not related to the 
Transmit Interrupt Status or the state of WR7' bit D5, but it 
shows the status of the exit location of the Transmit FIFO. 
This means more data can be written without being over- 
written. This bit is set to 1 when the Transmit FIFO is empty. 
It is reset when more than one character is loaded into the 
Transmit FIFO. 

This bit is always in the set condition after a hardware or 
channel reset. 

For more information on this bit, refer to Section 2.4.8 
"Transmit Interrupts and Transmit Buffer Empty bit". 

Bit 1 : Zero Count status. 

If the Zero Count interrupt Enable bit is set in WR1 5, this bit 
is set to one while the counter in the baud rate generator is 
at the count of zero. If there is no other External/Status 
interrupt condition pending at the time this bit is set, an 
External/Status interrupt is generated. However, if there is 
another External/Status interrupt pending at this time, no 
interrupt is initiated until interrupt service is complete. If the 
Zero Count condition does not persist beyond the end of 
the interrupt service routine, no interrupt is generated. This 
bit is not latched High, even though the other External/ 
Status latches close as a result of the Low-to-High transi- 
tion on ZC. The interrupt routine checks the other External/ 
Status conditions for changes. If none changed, ZC was 
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the source. In polled applications, checkthe IP bit in RR3A 
for a status change and then proceed as in the interrupt 
service routine. 

Bit 0: Receive Character Available. 

This bit is set to 1 when at least one character is available 
in the receive data FIFO. It is reset when the receive data 
FIFO is completely empty. A channel or hardware reset 
empties the receive data FIFO. 

On the ESCC, the status of this bit is independent of WR7' 
bit D3. 

For details on this bit, refer to Section 2.4.7, The Receive 
Interrupt. 

5.3.2 Read Register 1 

RR1 contains the Special Receive Condition status bits 
and the residue codes for the l-field in SDLC mode. Figure 
5-20 shows the bit positions for RR1 . 

Read Register 1 



| D7 1 D6 | D5 1 D4 D3 1 D2 1 D1 | DO | 



L_ 



All Sent 

Residue Code 2 
Residue Code 1 
Residue Code 
Parity Error 
Rx Overrun Error 
CRC/Framing Error 
End of Frame (SDLC) 



Figure 5-20. Read Register 1 



Bit 7: End of Frame (SDLC) status. 

This bit is used only in SDLC mode and indicates that a 
valid closing flag has been received and thatthe CRC Error 
bit and residue codes are valid. This bit is reset by issuing 
the Error Reset command. It is also updated by the first 
character of the following frame. This bit is reset in any 
mode other than SDLC. 

Bit 6: CRC/Framing Error status. 

If a framing error occurs (in Asynchronous mode), this bit 
is set (and not latched) for the receive character in which 
the framing error occurred. Detection of a framing error 
adds an additional one-half bit to the character time so that 
the framing error is not interpreted as a new Start bit. In 



Synchronous and SDLC modes, this bit indicates the result 
of comparing the CRC checker to the appropriate check 
value. This bit is reset by issuing an Error Reset command, 
but the bit is never latched. Therefore, it is always updated 
when the next character is received. When used for CRC 
error status in Synchronous or SDLC modes, this bit is 
usually set since most bit combinations, except for a 
correctly completed message, result in a non-zero CRC. 

On the CMOS and ESCC, if the Status FIFO is enabled 
(refer to the description in Write Register 1 5, bit D2 and the 
description in Read Register 7, bits D7 and D6), this bit 
reflects the status stored at the exit location of the 
Status FIFO. 

Bit 5: Receiver Overrun Error status. 

This bit indicates that the Receive FIFO has overflowed. 
Only the character that has been written over is flagged 
with this error. When that character is read, the Error 
condition is latched until reset by the Error Reset com- 
mand. Also, a Special Receive Condition vector is re- 
turned, caused by the overrun characters and all subse- 
quent characters received until the Error Reset command 
is issued. 

On the CMOS and ESCC, if the Status FIFO is enabled 
(refer to the description in Write Register 1 5, bit D2 and the 
description in Read Register 7, bits D7 and D6), this bit 
reflects the status stored at the exit location of the 
Status FIFO. 

Bit 4: Parity Error status. 

When parity is enabled, this bit is set for the characters 
whose parity does not match the programmed sense 
(even/odd). This bit is latched so that once an error occurs, 
it remains set until the Error Reset command is issued. If 
the parity in Special Condition bit is set, a parity error 
causes a Special Receive Condition vector to be returned 
on the character containing the error and on all subsequent 
characters until the Error Reset command is issued. 

Bits 3, 2, and 1 : Residue Codes, bits 2, 1 , and 0. 

In those cases in SDLC mode where the received l-Field is 
not an integral multiple of the character length, these three 
bits indicate the length of the l-Field and are meaningful 
only for the transfer in which the end of frame bit is set. This 
field is set to 011 by a channel or hardware reset and is 
forced to this state in Asynchronous mode. These three 
bits can leave this state only if SDLC is selected and a 
character is received. The codes signify the following 
(Reference Table 5-11) when a receive character length is 
eight bits per character. 
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On the CMOS and ESCC, if the Status FIFO is enabled 
(refer to the description in Write Register 1 5, bit D2 and the 
description in Read Register 7, bits D7 and D6), these bits 
reflect the status stored at the exit location of the 
Status FIFO. 



I-Field bits are right-justified in all cases. If a receive 
character length other than eight bits is used for the l-Field, 
a table similar to Table 5-1 1 can be constructed for each 
different character length. Table 5-12 shows the residue 
codes for no residue (The I-Field boundary lies on a 
character boundary). 



Table 5-1 1 . I-Field Bit Selection (8 Bits Only) 


Bit 3 


Bit 2 


Bit 1 


I-Field Bits in Last Byte 


I-Field Bits in Previous Byte 


1 











3 





1 








4 


1 


1 








5 








1 





6 


1 





1 





7 





1 


1 





8 


1 


1 


1 


1 


8 











2 


8 



Table 5-12. Bits per Character Residue Decoding 



Bits per Character 


Bit 3 


Bit 2 


Bit! 


8 





1 


1 


7 











6 





1 





5 








1 



Bit 0: All Sent status. 

In Asynchronous mode, this bit is set when all characters 
have completely cleared the transmitter pins. Most modems 
contain additional delays in the data path, which requires 
the modem control signals to remain active until after the 
data has cleared both the transmitter and the modem. This 
bit is always set in synchronous and SDLC modes. 

5.3.3 Read Register 2 

RR2 contains the interrupt vector written into WR2. When 
the register is accessed in Channel A, the vector returned 
is the vector actually stored in WR2. When this register is 
accessed in Channel B, the vector returned includes 
status information in bits 1 , 2 and 3 or in bits 6, 5 and 4, 



depending on the state of the Status High/Status Low bit in 
WR9 and independent of the state of the VIS bit in WR9. The 
vector is modified according to Table 5-6 shown in the 
explanation of the VIS bit in WR9 (Section 5.2.11). If no 
interrupts are pending, the status is V3.V2.V1 -011, or 
V6.V5.V4-1 10. Figure 5-21 shows the bit positions for RR2. 

Read Register 2 

| D7 1 D6 1 D5| D4| D3| D2 1 D1 | Do| 



VO 
V1 
V2 
V3 
V4 
V5 
V6 
V7 



» Interrupt 
f Vector * 



Modified In B Channel 



Figure 5-21 . Read Register 2 
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5.3.4 Read Register 3 



5.3.8 Read Register 7 (Not on NMOS) 



RR3 is the interrupt Pending register. The status of each of 
the interrupt Pending bits in the SCC is reported in this 
register. This register exists only in Channel A. If this 
register is accessed in Channel B, all Os are returned. The 
two unused bits are always returned as 0. Figure 5-22 
shows the bit positions for RR3. 

Read Register 3 



[*D7 D6 | D5 1 D4 | D3 1 D2 1 D1 | DO | 



Channel B Ext/Status IP 
Channel BTx IP 
Channel B Rx IP 
Channel A Ext/Status IP 
Channel A Tx IP 
Channel A Rx IP 





* Always In B Channel 



Figure 5-22. Read Register 3 



5.3.5 Read Register 4 (ESCC Only) 

On the ESCC, Read Register 4 reflects the contents of 
Write Register 4 provided the Extended Read option is 
enabled. Otherwise, this register returns an image of RRO. 

On the NMOS/CMOS version, a read to this location 
returns an image of RRO. 

5.3.6 Read Register 5 (ESCC Only) 

On the ESCC, Read Register 5 reflects the contents of 
Write Register 5 provided the Extended Read option is 
enabled. Otherwise, this register returns an image of RR1 . 

On the NMOS/CMOS version , a read to this register returns 
an image of RR1 . 

5.3.7 Read Register 6 (Not on NMOS) 

On the CMOS and ESCC, Read Register 6 contains the 
least significant byte of the frame byte count that is cur- 
rently at the top of the Status FIFO. RR6 is shown in Figure 
5-23. This register is readable only if the FIFO is enabled 
(refer to the description Write Register 15, bit D2 and 
Section 4.4.3). Otherwise, this register is an image of RR2. 



On the CMOS and ESCC, Read Register 7 contains the 
most significant six bits of the frame byte count that is 
currently at the top of the Status FIFO. Bit D7 is the FIFO 
Overflow Status and bit D6 is the FIFO Data Available 
Status. The status indications are given in Table 5-13. RR7 
is shown in Figure 5-24. This register is readable only if the 
FIFO is enabled (refer to the description Write Register 15, 
bit D2). Otherwise this register is an image of RR3. Note, for 
proper operation of the FIFO and byte count logic, the 
registers should be read in the following order: RR7, RR6, 
RR1. 

Read Register 6 * 

| D7 1 D6| D5 1 D4 1 D3 1 D2| D1 | Dp| 



BCO 
BC1 
BC2 
BC3 
BC4 
BC5 
BC6 
BC7 



Can only be accessed if the SDLC FIFO enhancement 
Is enabled (WR15 bit D2 set to 1) 

SDLC FIFO Status and Byte Count (LSB) 



Figure 5-23. Read Register 6 (Not on NMOS) 



Read Register 7 * 

| D7 1 D6 1 D5 1 D4 1 D3 j D2 1 D1 1 DO j 



BC8 

BC9 

BC10 

BC11 

BC12 

BC13 

FDA: FIFO Data Available 
1 = Status Reads from FIFO 

= Status Reads from ESCC 

FOS: FIFO Overflow Status 

1 = FIFO Overflowed 
= Normal 



Can only be accessed if the SDLC FIFO enhancement 
is enabled (WR15 bit D2 set to 1) 

SDLC FIFO Status and Byte Count (MSB) 



On the NMOS version, a read to this register location 
returns an image of RR2. 



Figure 5-24. Read Register 7 (Not on NMOS) 
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Table 5-13. Read Register 7 FIFO Status Decoding 



Bit 7: One Clock Missing status. 



Bit D7 FIFO Data Available Status 



1 


Status reads come from Fl FO 




(FIFO is not Empty) 





Status reads bypass FIFO 




(because FIFO is Empty) 



Bit D6 FIFO Overflow Status 



1 FIFO has overflowed 

Normal operation 



If the FIFO overflows, the FIFO and the FIFO Overflow 
Status bit are cleared by disabling and then re-enabling 
the FIFO through the FIFO control bit (WR15, D2). Other- 
wise, this register returns an image of RR3. 

On the NMOS version, a read to this location returns an 
image of RR3. 

5.3.9 Read Register 8 

RR8 is the Receive Data register. 

5.3.10 Read Register 9 (ESCC Only) 

On the ESCC, Read Register 9 reflects the contents of 
Write Register 3 provided the Extended Read option has 
been enabled. 

On the NMOS/CMOS version, a read to this location 
returns an image of RR13. 

5.3.11 Read Register 10 

RR10 contains some miscellaneous status bits. Unused 
bits are always 0. Bit positions for RR10 are shown in 
Figure 5-25. 



Read Register 10 

D7| D6| D5| D4| D3| D2I D1 1 DO 




On Loop 




While operating in the FM mode, the DPLL sets this bit to 
1 when it does not see a clock edge on the incoming lines 
in the window where it expects one. This bit is latched until 
reset by a Reset Missing Clock or Enter Search Mode 
command in WR14. In the NRZI mode of operation and 
while the DPLL is disabled, this bit is always 0. 

Bit 6: Two Clocks Missing status. 

While operating in the FM mode, the DPLL sets this bit to 
1 when it does not see a clock edge in two successive tries. 
At the same time the DPLL enters the Search mode. This 
bit is latched until reset by a Reset Missing Clock or Enter 
Search Mode command in WR14, bit 5-7. In the NRZI mode 
of operation and while the DPLL is disabled, this bit is 
always 0. 

Bit 4: Loop Sending status. 

This bit is set to 1 in SDLC Loop mode while the transmitter 
is in control of the Loop, that is, while the SCC is actively 
transmitting on the loop. This bit is reset at all other times. 

This bit can be polled in SDLC mode to determine when the 
closing flag has been sent. 

Bit 1 : On Loop status. 

This bit is set to 1 while the SCC is actually on loop in SDLC 
Loop mode. This bit is set to 1 intheX21 mode (Loop mode 
selected while in monosync) when the transmitter goes 
active. This bit is at all other times. This bit can also be 
pulled in SDLC mode to determine when the closing flag 
has been sent. 

5.3.12 Read Register 11 (ESCC Only) 

On the ESCC, Read Register 1 1 reflects the contents of 
Write Register 10 provided the Extended Read option has 
been enabled. Otherwise, this register returns an image of 
RR15 

On the NMOS/CMOS version, a read to this location 
returns an image of RR15 



1 o 

' Loop Sending 



——————— — — — — Two Clocks Missing 

— — — — — — — — — — — One Clock Missing 

Figure 5-25. Read Register 10 
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5.3.13 Read Register 12 



5.3.15 Read Register 14 (ESCC Only) 



RR12 returns the value stored in WR12, the lower byte of 
the time constant, for the BRG. Figure 5-26 shows the bit 
positions for RR12. 



Read Register 12 

EI 



D6l D5l D4| D3 



3| D2| E 



TCO 
TC1 
TC2 
TC3 
TC4 
TC5 
TC6 
TC7 J 



> Lower Byte 
of - " 



Time Constant 



Figure 5-26. Read Register 12 
5.3.14 Read Register 13 

RR13 returns the value stored in WR13, the upper byte of 
the time constant for the BRG. Figure 5-27 shows the bit 
positions for RR13. 

Read Register 13 



I D7 1 D6 1 D5 1 D4 1 D3 1 D2 1 D1 



El 



TC8 
TC9 
TC10 
TC11 
TC12 
TC13 
TC14 
TC15 J 



> Upper Byte 
of 



Time Constant 



On the ESCC, Read Register 14 reflects the contents of 
Write Register 7 Prime provided the Extended Read option 
has been enabled. Otherwise, this register returns an 
image of RR10. 

On the NMOS/CMOS version, a read to this location 
returns an image of RR10 

5.3.16 Read Register 15 

RR1 5 reflects the value stored in WR1 5, the External/Status 
IE bits. The two unused bits are always returned as Os. 
Figure 5-28 shows the bit positions for RR15. 



Read Register 15 
| D7 1 D6 1 



D5 D4 D3 D2 D1 



Zero Count IE 


DCDIE 
Sync/Hunt IE 
CTSIE 

Tx Underrun/EOM IE 
Break/Abort IE 



Figure 5-28. Read Register 15 



Figure 5-27. Read Register 13 
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USER'S MANUAL 



Chapter 6 

Z85C30 SL1480 VERSION 



6.1 INTRODUCTION 

This appendix describes the newly added functions to the 
SL (Special Lot) 1480 version of the CMOS SCC. 

6.1.1 General 

The SL1 480 version (SL: Special Lot) of the Z85C30 CMOS 
SCC is a new addition to the SCC family of products. 

This version of the Z85C30 has been developed to ease 
design and to reduce overhead, while maintaining 100% 
hardware/software compatibility. It has the following new 
features and enhancements over the Z85C30: 

■ New programmable WR7' (write register 7 prime) 
to enable new features. 

■ Improvements to support SDLC mode of 
synchronous communication: 

Improved functionality to ease sending 
back-to-back frames 

- Automatic SDLC opening Flag transmission* 
Automatic Tx Underrun/EOM Latch reset in 
SDLC mode* 

Automatic /RTS deactivation* 

- TxD pin forced "H" in SDLC NRZI mode 
after closing flag* 

- Complete CRC reception* 

Improved response to Abort sequence in 
status FIFO 

- Automatic Tx CRC generator preset/reset 
Extended read for write registers* 

Write data setup timing improvement 

■ Improved AC timing: 

Three to 3.5 PCLK access recovery time. 

- Programmable /DTR//REQ timing* 
Elimination of write data to falling edge of /WR 
setup time requirement 

Reduced /INT timing 

■ Other features include: 

Extended read function to read back the written 
value to the write registers* 
Latching RRO during read 

- RRO, bit D7 and RR10, bit D6 now has reset 
default value. 



Some of the features listed above are available by default, 
and some of them (features with "*") are disabled on 
default to maintain compatibility with the existing SCC 
design, and "program to enable" viaWR7'. 

For a further description, refer to the SCC technical manual 
portion of this manual. Some of the AC timing parameters 
have been modified from the Z85C30. For these, refer to 
the CPS (Customer Procurement Specification), which can 
be obtained from Zilog sales offices. 

6.2 Functional Descriptions 

This section describes the new features/enhancements 
made to the SL1480 version of the Z85C30. Functions 
other than those noted here are identical to the Z85C30 
CMOS SCC. These standard functions are covered else- 
where in this manual. 

6.2.1 New Programmable WR7' (Write 
Register 7 Prime) 

A new register, WR7', has been added to this version of the 
SCC to facilitate the programmed seven new features. 
WR7' is written to by first setting bit DO of WR15 to 1 , and 
pointing to WR7 as normal. All writes to register 7 will be to 
WR7' so long as WR DO is set. WR 1 5 bit DO must be reset 
to to address the sync register, WR7. If bit D6 of WR7' was 
set during the write, then WR7' can be read by accessing 
to RR14. The features remain enabled until specifically 
disabled, or disabled by a hardware or software reset. 
Figure 6-1 shows WR7'. 

WR 7 Prime 

D7| D6| D5| D4| D3| D2| Dl| Do| 

I Auto Tx Flag 

■ Auto EOM Reset 

' Auto /RTS Deactivation 

* Force TxD High 

■ /DTR//REQ Fast Mode 

' Complete CRC Reception 

' Extended Read Enable 

' Reserved (Program as 0) 

Figure 6-1. Write Register 7 Prime (WR7 1 ) 
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Write Register 7 Prime (WR7') has the following fields: 

Bit 7: Reserved. This bit is reserved and must be pro- 
grammed as 0. 

Bit 6: Extended Read Enable. This bit enables the Ex- 
tended Read. Setting this bit enables the reading of WR3, 
WR4, WR5, WR7' and WR10. When this feature is enabled, 
these registers can be accessed by reading RR9, RR4, 
RR5, RR14 and RR11, respectively. When this feature is 
not enabled, register access is to the SCC. In this case, 
read to these register locations returns RR13, RRO, RR1, 
RR10 and RR15, respectively. 

Bit 5: Receive Complete CRC. On this version, with this bit 
set to 1 , the 2nd byte of the CRC is received completely. 
This feature is ideal for applications which require a 2nd 
CRC byte for complete data; for example, a protocol 
analyzer or applications using other than CRC-CCITT CRC 
(i.e., 32-bit CRC). 

In SDLC mode of operation, the NMOS/CMOS SCC and 
this version of CMOS SCC, on this bit is programmed as 0. 
In this case on the EOF condition (when the closing flag is 
detected), the contents of the Receive Shift Register are 
transferred to the Receive Data FIFO regardless of the 
number of bits assembled. Because of the three-bit delay 
path between the sync register and the Receive Shift 
register, the last two bits of the 2nd byte of the CRC are 
never transferred to the Receive Data FIFO. The data is 
actually formed with the two Most significant Bits from the 
1 st CRC byte, with the six Least Significant Bits of the 2nd 
CRC byte. 

Bit 4: /DTR//REQ Fast Mode. If this bit is set and the 
/DTR//REQ pin is used for Request Mode (WR14, bit 



D2=1 ), the deactivation of the /DTR//REQ pin is identical to 
the /W//REQ pin, which is triggered on the falling edge of 
the/WR signal, andthe/DTR//REQ pin goes inactive below 
200 ns (this number varies depending on the speed grade 
of the device). When this bit is reset to 0, the deactivation 
time for the /DTR//REQ pin is 4TcPc. This latter operation 
is identical to that of the NMOS/CMOS version of the SCC. 

Bit 3: Force TxD High. On this version of the CMOS SCC, 
in the SDLC mode of operation with the NRZI encoding 
mode, there is an option to force TxD High. If bit DO of 
WR1 5 is set to 1 , bit D3 of WR7 1 can be used to set the TxD 
pin High. Note that the operation of this bit is independent 
of the Tx Enable bit in WR5. The Tx Enable bit in WR5 is 
used to control transmission activities, whereas bit D3 of 
WR7' acts as a pseudo transmitter disable and enable by 
forcing the TxD pin High when set, even though the 
transmitter may actually be mark or flag idling. Care must 
be exercised when setting this bit because any character 
being transmitted at the time that bit is set is "chopped off" ; 
data written to the Transmit Buffer while this bit is set is lost. 

On the NMOS/CMOS version of the SCC, if NRZI encoding 
is being used and the transmitter is disabled, the state of 
the TxD pin will depend on the last bit sent. That is, TxD pin 
may idle either in a Low or High state. 

Bit D2: Auto /RTS pin deactivation. This bit controls the 
timing of the deassertion of the /RTS pin. If this device is 
programmed for SDLC mode and Flag-On-Underrun 
(WR10, bit D2=0), this bit is set and the RTS bit is reset. The 
/RTS is deasserted automatically at the last bit of the 
closing flag, triggered by the rising edge of the TxC. The 
timing for this is shown in Figure 6-2. If this bit is reset to 0, 
the /RTS pin follows the state programmed in WR5 bit D1 . 



TxD Data 



Tx Underrun/EOM 
RTS Bit(WR5 D1) 
/RTS Pin 



5 



CRC1 



CRC2 



I Flag 




Figure 6-2. Auto /RTS Deactivation Timing 
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Bit D1 : Automatic Tx Underrun/EOM Latch Reset. If this bit 
is set, this version automatically resets the Tx Underrun/ 
EOM latch and presets the transmit CRC generator to its 
programmed preset state (the values set in WR5 D2 and 
WR10 D7). This removes the requirement to issue the reset 
Tx Underrun/EOM latch command. If this bit is reset, this 
device is identical to the NMOS/CMOS SCC. 

Bit DO: Automatic SDLC opening flag transmission. If this 
bit is set, the device automatically transmits an SDLC 
opening flag before transmitting data. This removes the 
requirementto resetthe mark idle bit (WR1 0, bit D3) before 
writing data to the transmitter or having to enable the 
transmitter before writing data to the transmit buffer. If this 
bit is reset, operation is identical to that of the NMOS/ 
CMOS SCC. Also, this feature enables a write transmit data 
before enabling the transmitter. 

6.2.2 Timing Improvements 

To ease the hardware design, the SL1480 version of the 
CMOS SCC has the following timing improvements: 

Three to 3.5 TcPc Access Recovery Time: The bus inter- 
face design of the SCC is asynchronous to the PCLK, 
which means there is no timing specification between /RD 
or /WR to its PCLK for avoiding meta-stable conditions. 
Therefore, the SCC has a "Valid Access Recovery Time" 
specification which applies to the transactions involving 
the SCC and is 4TcPc (Parameter #49, Trc). 

This version of the SCC has improved the parameter to: 
3 TcPc minimum if /RD and /WR are synchronized 
to PCLK 

- 3.5TcPc minimum, if/RDand/WR are not synchronized 
to PCLK. 

This improvement is ideal for applications which use a 
CPU with high bus bandwidth, such as a RISC processor, 
or for applications using DMA. Also, this feature eases the 
design of applications which run the CPU and SCC at 
different clock speeds. 

Programmable /DTR//REQ Timing: Refer to the descrip- 
tion of bit D4 in Section 2.1. If bit D4 of WR7' is set, 
deactivation timing of the /DTR//REQ pin is made identical 
to the /WAIT//REQ pin. With the NMOS/CMOS version of 
the SCC, timing is 4TcPc with some of the DMA devices 
seeing the period as "still requesting to transfer." This 
initiates another DMA transfer and potentially overwrites 
the data, which results in erroneous transmission. Timing 
modifications using external circuits for these designs are 
no longer needed with this feature. 



Write data valid setup time to /WR requirement eliminated: 
To simplify the CPU interface, the AC timing parameter 
#29, Write Data to /WR falling minimum, has been changed 
to: /WR falling to Write Data Valid maximum. This modifica- 
tion is to allow a maximum delay from the /WR signal going 
active Low to the latching of the data bus. 

Reduced INT Response Time: The interrupt response time 
of this version has been improved so that the /INT pin 
(regardless of the interrupt source) is asserted Low 2 TcPc 
earlier (compare to the NMOS/CMOS version of the SCC). 

6.2.3. Other Improvements 

Transmission of back-to-back frames with Shared Flag: In 
order to transmit back-to-back frames using a shared flag, 
data for the next frame is written to the transmit buffer after 
the Tx Underrun/EOM Interrupt. This data is transmitted 
after the CRC and closing flag, i.e., the closing flag of the 
current frame is the opening flag of the next frame being 
transmitted. This occurs independently of the SDLC Auto 
Flag feature. 

It is expected that the customer using this feature should 
enable the "Automatic EOM Reset" feature. If this feature 
is not used, the user should not issue the "Reset Tx/ 
Underrun EOM Latch command" or the "Reset CRC Gen- 
erator" command until after the CRC has completed trans- 
mission. 

Improved response to abort in the SDLC status FIFO: If a 
frame is terminated with an Abort sequence, the byte count 
is loaded to the status FIFO and the counter reset for the 
next frame. 

Auto Tx CRC generator reset/preset: If automatic Tx 
Underrun EOM Latch Reset mode is enabled (WR7 1 bit 
D1 =1 ), the transmit CRC generator is preset automatically 
every time an opening flag is sent, so the Reset CRC 
Generator command is not necessary. 

Latch RRO during Read transaction: On the NMOS/CMOS 
version, a read to RRO will not latch the contents of the 
register; hence, there is a possibility for reading out unpre- 
dictable data. This version latches the contents of RRO on 
the falling edge of the /RD strobe, and releases the latch on 
the rising edge of it. 
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Register Default Values: On the NMOS/CMOS version, 
RRO bit D7, RR1 bit DO and RR10 bit D6 do not have default 
value on the Reset. This version of the SCC has the 
following value on the reset. 





NMOS/CMOS 


SL1480 


RRO 


x1xxx110 


01xxx100 


RR1 


000001 1x 


00000111 


RR10 


0x000000 


00000000 



Note: 

x = undetermined 
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Application Notes 



Application Note 



Interfacing Z80 
cpus to the z8500 
Peripheral Family 



INTRODUCTION 

The Z8500 Family consists of universal peripherals 
that can interface to a variety of microprocessor 
systems that use a non -mul tiplexed address and 
data bus. Though similar to Z80 peripherals, the 
Z8500 peripherals differ in the way they respond 
to I/D and Interrupt Acknowledge cycles. In 
addition, the advanced features of the Z850O 
peripherals enhance system performance and reduce 
processor overhead. 

To design an effective interface, the user needs 
an understanding of how the Z80 Family interrupt 
structure works, and how the Z8500 peripherals 
interact with this structure. This application 
note provides basic information on the interrupt 
structures, as well as a discussion of the 
hardware and software considerations involved in 
interfacing the Z8500 peripherals to the Z80 
CPUs. Discussions center around each of the 
following situations: 

a Z80A 4 MHz CPU to Z85QO 4 MHz peripherals 

• Z80B 6 MHz CPU to Z85O0A 6 MHz peripherals 

• Z80H 8 MHz CPU to Z85O0 A MHz peripherals 
a Z80H 8 MHz CPU to Z85O0A 6 MHz peripherals 

This appl ication note assumes the reader has a 
strong working knowledge of the Z8500 peripherals; 
it is not intended as a tutorial. 

CPU HARDWARE INTERFACING 

The hardware interface consists of three basic 
groups of signals: data bus, system control, and 
interrupt control, described below. For more 
detailed signal information, refer to Zilog's 
Data Book , Universal Peripherals. 



Data Bus Signals 

D 7 -Dg Data Bus (bidirectional, 3-state) . This 
bus transfers data between the CPU and the 
peripherals. 

System Control Signals 

A n -A Q Address Select Lines (optional) . These 
lines select the port and/or control 
registers. 

CT Chip Enable (input, active Low). ClT is 
used to select the proper peripheral for 
programming. CT should be gated with 10RQ 
or MREQ to prevent spurious chip selects 
during other machine cycles. 

"RD* Read (input, active Low). "RD activates the 
chip-re.ad circuitry and gates data from the 
chip onto the data bus. 

W* Write (input, active Low). W strobes data 
from the data bus into the peripheral. 

*Chip reset occurs when W and W are active 
simultaneously . 

Interrupt Control 

1NTACK Interrupt Acknowledge (input, active Low). 
This signal indicates an Interrupt 
Acknowledge cycle and is used with TflT to 
gate the interrupt vector onto the data 
bus. 

INT Interrupt Request (output, open-drain, 
active Low) . 
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Figure 2. Z8500 Peripheral I/O Write Cycle Timing 



The IUS bit indicates that an interrupt is 
currently being serviced by the CPU. The IUS bit 
is set during an Interrupt Acknowledge cycle if 
the IP bit is set and the IE1 line is High. If 
the IEI line is Low, the IUS bit is not set, and 
the device is inhibited from placing its vector 
onto the data bus. In the Z80 peripherals, the 
IUS bit is normally cleared by decoding the RETI 
instruction, but can also be cleared by a software 
command (S 10). In the Z8500 peripherals, the IUS 
bit is cleared only by software commands. 

Z80 Interrupt Daisy-Chain Operation 

In the Z80 peripherals, both the IP and IUS bits 
control the IEO line and the lower portion of the 
daisy chain. 

When a peripheral's IP bit is set, its IE0 line is 
forced Low. This is true regardless of the state 
of the IEI line. Additionally, if the peripher- 
al's IUS bit is clear and its IEI line High, the 
INT line is also forced Low. 

The Z80 peripherals sample for both W and I0RQ 
active, and W inactive to identify an Interrupt 
Acknowledge cycle. When ITT goes active and "RD is 
inactive, the peripheral detects an Interrupt 
Acknowledge cycle and allows its interrupt daisy 
chain to settle. When the I0RQ line goes active 
with W active, the highest priority interrupting 
peripheral places its interrupt vector onto the 
data bus. The IUS bit is also set to indicate 
that the peripheral is currently under service. 
As long as the IUS bit is set, the IE0 line is 
forced Low. This inhibits any lower priority 
devices from requesting an interrupt. 



When the Z80 CPU executes the RETI instruction, 
the peripherals monitor the data bus and the high- 
est priority device under service resets its IUS 
bit. 

Z8500 Interrupt Daisy-Chain Operation 

In the Z8500 peripherals, the IUS bit normally 
controls the state of the IEO line. The IP bit 
affects the daisy chain only during an Interrupt 
Acknowledge cycle. Since the IP bit is normally 
not part of the Z8500 peripheral interrupt daisy 
chain, there is no need to decode the RETI in- 
struction. To allow for control over the daisy 
chain, Z8500 peripherals have a Disable Lower 
Chain (DLC) software command that pulls IEO Low. 
This can be used to selectively deactivate parts 
of the daisy chain regardless of the interrupt 
status. Table 1 shows the truth tables for the 
Z8500 interrupt daisy-chain control signals during 
certain cycles. Table 2 shows the interrupt state 
diagram for the Z8500 peripherals. 



Table 1. Z8500 Daisy-Chain Control Signals 



Truth Table for 


Truth Table for 


Daisy Chain Signals 


Daisy Chain Signals 


During Idle State 


During INTACK Cycle 


IEI IP IUS IEO 


IEI IP IUS IEO 



X X X X 
1X01 11X0 

1 X 10 1X10 

10 1 



Interrupt Enable In (input, active High). 

Interrupt Enable Out (output, active 
High) . 

These lines control the interrupt daisy 
chain for the peripheral interrupt 
response. 



Write Cycle Tilling 

Figure 2 illustrates the Z8500 Write cycle 
timing. All register addresses and INTACK must 
remain stable throughout the cycle. If "CT goes 
active after W goes active, or if "CT goes in- 
active before W goes inactive, then the effective 
Write cycle is shortened. Data must be available 
to the peripheral prior to the falling edge of W. 



Z8500 I/O OPERATION 

The Z8500 peripherals generate internal control 
signals from "RD" and "WR". Since PCLK has no 
required phase relationship to IflT or W, the 
circuitry generating these signals provides time 
for metastable conditions to disappear. 

The Z8500 peripherals are initialized for dif- 
ferent operating modes by programming the internal 
registers. These internal registers are accessed 
during I/O Read and Write cycles, which are 
described below. 



Read Cycle Tining 

Figure 1 illustrates the Z8500 Read cycle timing. 
All register addresses and INTACK must remain 
stable throughout the cycle. If T3ET goes active 
after TflJ goes active, or if "CE" goes inactive 
before W goes inactive, then the effective Read 
cycle is shortened. 



PERIPHERAL INTERRUPT OPERATION 

Understanding peripheral interrupt operation 
requires a basic knowledge of the Interrupt 
Pending (IP) and Interrupt Under Service (IUS) 
bits in relation to the daisy chain. Both Z80 and 
Z8500 peripherals are designed in such a way that 
no additional interrupts can be requested during 
an Interrupt Acknowledge cycle. This allows the 
interrupt daisy chain to settle, and ensures 
proper response of the interrupting device. 

The IP bit is set in the peripheral when CPU 
intervention is required (such conditions as 
buffer empty, character available, error detec- 
tion, or status changes). The Interrupt Ac- 
knowledge cycle does not necessarily reset the IP 
bit. This bit is cleared by a software command to 
the peripheral, or when the action that generated 
the interrupt is completed (i.e., reading a 
character, writing data, resetting errors, or 
changing the status). When the interrupt has been 
serviced, other interrupts can occur. 



ADDR 



X 



ADDRESS VALID 



X 



INTACK 



CE 



L 



RD 



\ 



DATA 
IN 



< 



DATA VALID 



> 



Figure 1. Z8500 Peripheral I/O Read Cycle Timing 



7-3 



Table 2. Z8500 Interrupt State Diagra 

Interrupt Condition 



IP Set 



IEI High? 



INT Active 



-> Wait for CPU INTACK Cycle 



INTACK * IEI * RD 



I US Set 



CPU Read, Write, or Reset IP 



IP Cleared 



IEO High? 



I US Cleared 



Return to main program 



The Z8500 peripherals use INTACK (Interrupt 
Acknowledge) for recognition of an Interrupt 
Acknowledge cycle. This pin, used in conjunction 
with RD, allows the Z8500 peripheral to gate its 
interrupt vector onto the data bus. An active RD 
signal during an Interrupt Acknowledge cycle 
performs two functions. First, it allows the 
highest priority device requesting an interrupt to 
place its interrupt vector on the data bus. 
Secondly, it sets the IUS bit in the highest 
priority device to indicate that the device is 
currently under service. 



INPUT/OUTPUT CYCLES 

Although Z8500 peripherals are designed to be as 
universal as possible, certain timing parameters 
differ from the standard Z80 timing. The 
following sections discuss the I/O interface for 
each of the Z80 CPUs and the Z8500 peripherals. 
Figure 5 depicts logic for the Z80A CPU to Z8500 
peripherals (and Z80B CPU to Z8500A peripherals) 
I/O interface as well as the Interrupt Acknowledge 



interface. Figures 4 and 7 depict some of the 
logic used to interface the Z80H CPU to the Z8500 
and Z8500A peripherals for the I/O and Interrupt 
Acknowledge interfaces. The logic required for 
adding additional Wait states into the timing flow 
is not discussed in the folowing sections. 



Z80A CPU to Z8500 Peripherals 

No additional Wait states are necessary during the 
I/O cycles, although additional Wait states can be 
inserted to compensate for timing delays that are 
inherent in a system. Although the Z80A timing 
parameters indicate a negative value for data 
valid prior to W, this is a worse than "worst 
case" value. This parameter is based upon the 
longest (worst case) delay for data available from 
the falling edge of the CPU clock minus the 
shortest (best case) delay for CPU clock High to 
W Low. The negative value resulting from these 
two parameters does not occur because the worst 
case of one parameter and the best case of the 
other do not occur within the same device. This 
indicates that the value for data available prior 
to W will always be greater than zero. 

All setup and pulse width times for the Z8500 
peripherals are met by the standard Z80A timing. 
In determining the interface necessary, the T!C" 
signal to the Z8500 peripherals is assumed to be 
the decoded address qualified with the 10RQ 
signal. 

Figure 3a shows the minimum Z80A CPU to Z8500 
peripheral interface timing for I/O cycles. If 
additional Wait states are needed, the same number 
of Wait states can be inserted for both I/O Read 
and Write cycles to simplify interface logic. 
There are several ways to place the Z80A CPU into 
a Wait condition (such as counters or shift 
registers to count system clock pulses), depending 
upon whether or not the user wants to place Wait 
states in all I/O cycles, or only during Z8500 I/O 
cycles. Tables 3 and 4 list the Z8500 peripheral 
and the Z80A CPU timing parameters (respectively) 
of concern during the I/O cycles. Tables 5 and 6 
list the equations used in determining if these 
parameters are satisfied. In generating these 
equations and the values obtained from them, the 
required number of Wait states was taken into 
account. The reference numbers in Tables 3 and 4 
refer to the timing diagram in Figure 3a. 
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Table 3. Z8500 Timing Parameters I/O Cycles 



Worst Case 









Min 


Max 


Units 


6. 


TsA(WR) 


Address to WR Low Setup 


80 




ns 


1. 


TsA(RD) 


Address to RD Low Setup 


80 




ns 


2. 


THAf OR"} 


AHHtpqq t - n RpaH Dat" a Valid 




590 






TsCEl(WR) 


CE Low to WR Low Setup 







ns 




TsCEl(RD) 


CE Low to RD Low Setup 







ns 


4. 


TwRDl 


RD Low Width 


390 




ns 


8. 


TwWRl 


WR Low Width 


390 




ns 


3. 


TdRDf(DR) 


RD Low to Read Data Valid 




255 


ns 


7. 


TsDW(WR) 


Write Data to WR Low Setup 







ns 


Table 4. Z80A Timing Parameters I/O Cycles 




Worst Case 
















Min 


Max 


Units 




TcC 


Clock Cycle Period 


250 




ns 




TwCh 


Clock Cycle High Width 


110 




ns 




TfC 


Clock Cycle Fall Time 




30 


ns 




TdCr(A) 


Clock High to Address Valid 




110 


ns 




TdCr(RDf) 


Clock High to RD Low 




85 


ns 




TdCr(IORQf) 


Clock High to IORQ Low 




75 


ns 




TdCr(WRf) 


Clock High to WR Low 




65 


ns 


5. 


TsD(Cf) 


Data to Clock Low Setup 


50 




ns 


Table 5. Parameter Equations 




Z8500 


Z80A 










Parameter 


Equation 


Value 


Units 




TsA(RD) 


TcC-TdCr(A) 


140 min 


ns 




TdA(DR) 


3TcC+TwCh-TdCr(A)-TsD(Cf) 


800 


min 


ns 




TdRDf(DR) 


2TcC+TwCh-TsD(Cf) 


460 


min 


ns 




TwRDl 


2TcC+TwCh+TfC-TdCr(RDf) 


525 


min 


ns 




TsA(WR) 


TcC-TdCr(A) 


140 


min 


ns 




TsDW(WR) 




> 


min 


ns 




TwWRl 


2TcC+TwCh+TfC-TdCr(WRf) 


560 


min 


ns 


Table 6. Parameter Equations 




Z80A 


Z8500 










Parameter 


Equation 


Value 


Units 




TsD(Cf) 


Address 












3TcC+TwCh-TdCr(A)-TdA(DR) 


160 


min 


ns 






RD 












2TcC+TwCh-TdCr ( RDf ) -TdRD(DR) 


135 


min 


ns 




Z80B CPU to Z8500A Peripherals 

No additional Wait states are necessary during I/O 
cycles, although Wait states can be inserted to 
compensate for any system delays. Although the 
Z80B timing parameters indicate a negative value 
for data valid prior to W, this is a worse than 
"worst case" value. This parameter is based upon 
the longest (worst case) delay for data available 
from the falling edge of the CPU clock minus the 
shortest (best case) delay for CPU clock High to 
W Low. The negative value resulting from these 



two parameters does not occur because the worst 
case of one parameter and the best case of the 
other do not occur within the same device. This 
indicates that the value for data available prior 
to W will always be greater than zero. 

All setup and pulse width times for the Z8500A 
peripherals are met by the standard Z80B timing. 
In determining the interface necessary, the 
signal to the Z8500A peripherals is assumed to be 
the decoded address qualified with the 10RQ 
signal . 
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Figure 3b shows the minimum Z80B CPU to Z8500A 
peripheral interface timing for I/O cycles. If 
additional Wait states are needed, the same number 
of Wait states can be inserted for both I/O Read 
and I/O Write cycles in order to simplify inter- 
face logic. There are several ways to place the 
Z80B CPU into a Wait condition (such as counters 
or shift registers to count system clock pulses) , 
depending upon whether or not the user wants to 
place Wait states in all I/O cycles, or only 



during Z8500A 1/0 cycles. Tables 7 and 8 list the 
Z8500A peripheral and the Z80B CPU timing 
parameters (respectively) of concern during the 
I/O cycles. Tables 9 and 10 list the equations 
used in determining if these parameters are satis- 
fied. In generating these equations and the 
values obtained from them, the required number of 
Wait states was taken into account. The reference 
numbers in Tables 7 and 8 refer to the timing 
diagram of Figure 3b. 



CLOCK 



ADDR 




IORQ 



CE 



RD 



READ 



CPU 
DATA IN 



\ 



\ 



\ 



\ 



-0- 



-©- 



r 

j 



r 



Jt 



-© 




Figure 3b. Z80B CPU to Z8500A Peripheral Minimum I/O Cycle Timing 
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Table 7. Z8500A Timing Parameters I/O Cycles 





Worst Case 




Nin 


Max 


Units 


6. 


TsA(WR) 


Address to WR Low Setup 


80 




ns 


1. 


TsA(RD) 


Address to RD Low Setup 


80 




ns 


2. 


TdA(DR) 


Address to Read Data Valid 




420 


ns 




TsClI(WR) 


CE Low to WR Low Setup 







ns 




TsCEl(RD) 


CE Low to RD Low Setup 







ns 


4. 


TwRDl 


RD Low Width 


250 




ns 


8. 


TwWRl 


WR Low Width 


250 




ns 


3. 


TdRDf(DR) 


RD Low to Read Data Valid 




180 


ns 


7. 


TsDW(WR) 


Write Data to WR Low Setup 







ns 


Table 8. Z80B Timing Parameters I/O Cycles 




Worst Case 




Min 


Max 


Units 




icC 


Clock Cycle Period 


165 




ns 




TwCh 


Clock Cycle High Width 


65 




ns 




TfC 


Clock Cycle Fall Time 




20 


ns 




TdCr(A) 


Clock High to Address Valid 




90 


ns 




TdCr(RDf) 


Clock High to RD Low 




70 


ns 




TdCr(IORQf) 


Clock High to IORQ Low 




65 


ns 




TdCr(WRf) 


Clock High to WR Low 




60 


ns 


5. 


TsD(Cf) 


Data to Clock Low Setup 


40 




ns 


Table 9. Parameter Equations 




Z8500A 


Z80B 










Parameter 


Equation 


Value 


Units 




TsA(RD) 


TcC-TdCr(A) 


>75 


min 


ns 




TdA(DR) 


3TcC+TwCh-T dCr ( A) -TsD ( Cf ) 


430 


min 


ns 




TdRDf(DR) 


2TcC+TwCh-TsD(Cf) 


345 


min 


ns 




TwRDl 


2TcC+TwCh+TfC-TdCr(RDf) 


325 


min 


ns 




TsA(WR) 


TcC-TdCr(A) 


75 


min 


ns 




TsDW(WR) 




> 


min 


ns 




TwWRl 


2TcC+TwCh+ T f C-TdCr ( WRf ) 


352 


min 


ns 



Table 10. Parameter Equations 



Z8500A 

Equation Value Units 



Address 

3TcC+TwCh-TdCr(A)-TdA(DR) 50 min ns 

RD 

2TcC+TwCh-TdCr(RDf )-TdRD(DR) 75 min ns 
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Z80H CPU to Z8500 Peripherals 

During an I/O Read cycle, there are three Z8500 
parameters that must be satisfied. Depending upon 
the loading characteristics of the "RU signal, the 
designer may need to delay the leading (falling) 
edge of flU to satisfy the Z8500 timing parameter 
TsA(RD) (Address Valid to W Setup). Since Z80H 
timing parameters indicate that the "EU signal may 
go Low after the falling edge of it is 

recommended that the rising edge of the system 
clock be used to delay "RE) (if necessary). The CPU 
must also be placed into a Wait condition long 
enough to satisfy TdA(DR) (Address Valid to Read 
Data Valid Delay) and TdRDf(DR) CRT) Low to Read 
Data Valid Delay) . 

During an I/O Write cycle, there are three other 
Z8500 parameters that must be satisfied. 
Depending upon the loading characteristics of the 
W signal and the data bus, the designer may need 
to delay the leading (falling) edge of WR to 
satisfy the Z8500 timing parameters TsA(WR) 
(Address Valid to W Setup) and TsDW(WR) (Data 
Valid Prior to W setup) . Since Z80H timing 
parameters indicate that the W signal may go Low 
after the falling edge of T 2 , it is recommended 
that the rising edge of the system clock be used 
to delay W (if necessary). This delay will 
ensure that both parameters are satisfied. The 
CPU must also be placed into a Wait condition long 



enough to satisfy TwWRl (W Low Pulse Width).. 
Assuming that the W signal is delayed, only two 
additional Wait states are needed during an I/O 
Write cycle when interfacing the Z80H CPU to the 
Z8500 peripherals. 

To simplify the 1/0 interface, the designer can 
use the same number of Wait states for both I/O 
Read and I/O Write cycles. Figure 3c shows the 
minimum Z80H CPU to Z8500 peripheral interface 
timing for the I/O cycles (assuming that the same 
number of Wait states are used for both cycles and 
that both TH) and W need to be delayed) . Figure 
4 shows two circuits that can be used to delay the 
leading (falling) edge of either the W or the W 
signals. There are several ways to place the Z80A 
CPU into a Wait condition (such as counters or 
shift registers to count system clock pulses), 
depending upon whether or not the user wants to 
place Wait states in all I/O cycles, or only 
during Z8500 I/O cycles. Tables 4 and 11 list the 
Z8500 peripheral and the Z80H CPU timing 
parameters (respectively) of concern during the 
I/O cycles. Tables 14 and 15 list the equations 
used in determining if these parameters are 
satisfied. In generating these equations and the 
values obtained from them, the required number of 
Wait states was taken into account. The reference 
numbers in Tables 4 and 11 refer to the timing 
diagram of Figure 3c. 



Table 11. Z80H Timing Parameter I/O Cycles 





Equation 


Min 


Max 


Units 


TcC 


Clock Cycle Period 


125 




ns 


TwCh 


Clock Cycle High Width 


55 




ns 


TfC 


Clock Cycle Fall Time 




10 


ns 


TdCr(A) 


Clock High to Address Valid 




80 


ns 


TdCr(RDf) 


Clock High to RD Low 




60 


ns 


TdCr(IORQf) 


Clock High to I0RQ Low 




55 


ns 


TdCr(WRf) 


Clock High to WR Low 




55 


ns 


5. TsD(Cf) 


Data to Clock Low Setup 


30 




ns 


Table 12. Parameter Equations 


Z850Q 


Z80H 








Parameter 


Equation 




Value 


Units 


TsA(RD) 


2TcC-TdCr(A) 




170 min 


ns 


TdA(DR) 


6TcC+TwCh-TdCr(A)-TsD(Cf) 




695 min 


ns 


TdRDf(DR) 


4TcC+TwCh-TsD(Cf) 




523 min 


ns 


TwRDl 


4TcC+TwCh+TfC-TdCr(RDf) 




503 min 


ns 


TsA(WR) 


WR - delayed 










2TcC-TdCr(A) 




170 min 


ns 


TsDW(WR) 






> min 


ns 


TwWRl 


4TcC+TwCh+TfC 




563 min 


ns 
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Z80H CPU to Z8500A Peripherals 

During an 1/0 Read cycle, there are three Z8500A 
parameters that must be satisfied. Depending upon 
the loading characteristics of the "EE) signal, the 
designer may need to delay the leading (falling) 
edge of "RT5" to satisfy the Z8500A timing parameter 
TsA(RD) (Address Valid to W Setup). Since Z80H 
timing parameters indicate that the "RIT signal may 
go Low after the falling edge of it is 

recommended that the rising edge of the system 
clock be used to delay W (if necessary). The CPU 
must also be placed into a Wait condition long 
enough to satisfy TdA(DR) (Address Valid to Read 
Data Valid Delay) and TdRDf(DR) (W Low to Read 
Data Valid Delay). Assuming that, the W signal is 
delayed, then only one additional Wait state is 
needed during an I/O Read cycle when interfacing 
the Z80H CPU to the Z8500A peripherals. 

During an 1/0 Write cycle, there are three other 
Z8500A parameters that have to be satisfied. 
Depending upon the loading characteristics of the 
W signal and the data bus, the designer may need 
to delay the leading (falling) edge of WR" to 
satisfy the Z8500A timing parameters TsA(WR) 
(Address Valid to W Setup) and TsDW(WR) (Data 
Valid Prior to W Setup) . Since Z80H timing 
parameters indicate that the W signal may go Low 
after the falling edge of it is recommended 

that the rising edge of the system clock be used 



to delay W (if necessary). This delay will 
ensure that both parameters are satisfied. The 
CPU must also be placed into a Wait condition long 
enough to satisfy TwWRl (W Low Pulse Width) . 
Assuming that the W signal is delayed, then only 
one additional Wait state is needed during an I/O 
Write cycle when interfacing the Z80H CPU to the 
Z8500A peripherals. 

Figure 3d shows the minimum Z80H CPU to Z8500A 
peripheral interface timing for the I/O cycles 
(assuming that the same number of Wait states are 
used for both cycles and that both "RD and W need 
to be delayed). Figure 4 shows two circuits that 
may be used to delay the leading (falling) edge of 
either the "RD" or the W signals. There are 
several methods used to place the Z80A CPU into a 
Wait condition (such as counters or shift 
registers to count system clock pulses) , depending 
upon whether or not the user wants to place Wait 
states in all I/O cycles, or only during Z8500A 
I/O cycles. Tables 7 and 11 list the Z8500A 
peripheral and the Z80H CPU timing parameters 
(respectively) of concern during the I/O cycles. 
Tables 14 and 15 list the equations used in 
determining if these parameters are satisfied. In 
generating these equations and the values obtained 
from them, the required number of Wait states was 
taken into account. The reference numbers in 
Tables 4 and 11 refer to the timing diagram of 
Figure 3d. 



Table 13. Parameter Equations 



Z80H Z8500 
Parameter Equation Value Units 



TsD(Cf) Address 

6TcC+TwCh-TdCr(A)-TdA(DR) 135 min ns 

RD - delayed 

4TcC+TwCh+TfC-rdRD(DR) 300 min ns 



Table 14. Parameter Equations 



Z8500A Z80H 

Parameter Equation Value units 

TsA(RD) 2TcC-TdCr(A) 170 min ns 

TdA(DR) 6TcC+TwCh-TdCr(A)-TsD(Cf) 695 min ns 

TdRDf(DR) 4TcC+TwCh-TsD(Cf) 525 min ns 

TwRDl 4TcC+TwCh+TfC-TdCr(RDf) 503 mm ns 

TsA(WR) WR - delayed 

2TcC-TdCr(A) 170 min ns 

TsDW(WR) > min ns 

TwWRl 2TcC+TwCh+TfC 313 min ns 



7-11 




7-12 




74LS74 



RDD (WRD) 



RD (WR) 
CLOCK 



r>° — i 

74LS04 



s 




D 


Q 


CK 


Q 


C 





RDD (WRD) 



74LS74 



CLOCK 



RD (WR) 



D 

CK 



74LS04 



RDD (WRD) 



74LS74 



Figure 4. Delaying RD or WR 



Table 15. Parameter Equations 



Z80H 
Parameter 



Z8500A 
Equation 



Value Units 



TsD(Cf) 



Address 

4TcC+TwCh-TdCr(A)-TdA(DR) 
RD - delayed 
2TcC+TwCh-TdRD(DR) 



55 min ns 
125 min ns 
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INTERRUPT ACKNOWLEDGE CYCLES 

The primary timing differences between the Z80 
CPUs and Z8500 peripherals occur in the Interrupt 
Acknowledge cycle. The Z8500 timing parameters 
that are significant during Interrupt Acknowledge 
cycles are listed in Table 16, while the Z80 
parameters are listed in Table 17. The reference 
numbers in Tables 16 and 17 refer to Figures 6, 
8a, and 8b. 

If the CPU and the peripherals are running at 
different speeds (as with the Z80H interface), the 
INTACK signal must be synchronized to the 
peripheral clock. Synchronization is discussed in 
detail under Interrupt Acknowledge for Z80H CPU to 
Z8500/8500A Peripherals. 

During an Interrupt Acknowledge cycle, Z8500 
peripherals require both INTACK and RD to be 
active at certain times. Since the Z80 CPUs do 
not issue either INTACK or RD, external logic must 
generate these signals. 

Generating these two signals is easily ac- 
complished, but the Z80 CPU must be placed into a 
Wait condition until the peripheral interrupt 
vector is valid. If more peripherals are added to 
the daisy chain, additional Wait states may be 



necessary to give the daisy chain time to settle. 
Sufficient time between INTACK active and RD 
active should be allowed for the entire daisy 
chain to settle. 

Since the Z8500 peripheral daisy chain does not 
use the IP flag except during interrupt 
acknowledge, there is no need for decoding the 
RETI instruction used by the Z80 peripherals. In 
each of the Z8500 peripherals, there are commands 
that reset the individual IUS flags. 

EXTERNAL INTERFACE LOGIC 

The following sections discuss external interface 
logic required during Interrupt Acknowledge cycles 
for each interface type. 

CPU/Peripheral Same Speed 

Figure 5 shows the logic used to interface the 
Z80A CPU to the Z8500 peripherals and the Z80B CPU 
to Z8500A peripherals during an Interrupt 
Acknowledge cycle. The primary component in this 
logic is the Shift register (74LS164), which 
generates INTACK, WW, and TOT. 



Table 16. Z8500 Timing Parameters Interrupt Acknowledge Cycles 



Worst Case 4 MHz 6 MHz 

Min Max Min Max Units 



1. 


TsIA(PC) 


INTACK Low to PCLK High Setup 


100 


100 


ns 




ThlA(PC) 


INTACK Low to PCLK High Hold 


100 


100 


ns 


2. 


TdlAi(RD) 


INTACK Low to RD (Acknowledge) Low 


350 


250 


ns 


5. 


TwRDA 


RD (Acknowledge) Width 


350 


250 


ns 


3. 


TdRDA(DR) 


RD (Acknowledge) to Data Valid 


250 


180 


ns 




TsIEI(RDA) 


IEI to RD (Acknowledge) Setup 


120 


100 


ns 




ThlEI(RDA) 


IEI to RD (Acknowledge) Hold 


100 


70 


ns 




TdlEI(IE) 


IEI to IEO Delay 


150 


100 


ns 



Table 17. Z80 CPU Timing Parameters Interrupt Acknowledge Cycles 



Worst Case 




4 MHz 


6 MHz 


8 MHz 








Min Max 


Min Max 


Min Max 


Units 


TdC(M1f) 


Clock High to Ml Low Delay 


100 


80 


70 


ns 


TdM1f(I0RQf) 


Ml Low to I0RQ Low Delay 


575* 


345* 


275* 


ns 


4. TsD(Cr) 


Data to Clock High Setup 


35 


30 


25 


ns 



*Z80A: 2TcC + TwCh + TfC - 65 
Z80B: 2TcC + TwCh + TfC - 50 
Z80H: 2TcC + TwCh + TfC - 45 
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Figure 5. Z80A/Z80B CPU to Z8500/Z8500A Peripheral Interrupt Acknowledge Interface Logic 



During I/O and normal memory access cycles, the 
Shift register remains cleared because the "RT 
signal is inactive. During opcode fetch cycles, 
also, the Shift register remains cleared, because 
only Os can be clocked through the register. 
Since Shift register outputs are Low, READ, 
WRITE, and WAIT are controlled by other system 
logic and gated through the AND gates (74LS11). 
During I/O and normal memory access cycles, READ 
and WRITE are active as a result of the system W 
and W signals (respectively) becoming active. 
If system logic requires that the CPU be placed 
into a Wait condition, the WAIT 1 signal controls 
the CPU. Should it be necessary to reset the 
system, RESET causes the interface logic to 
generate both "kTaTJ and WRITE (the Z8500 peripheral 
Reset condition) . 

Normally an Interrupt Acknowledge cycle is 
indicated by the Z80 CPU when W and ToTflT are both 
active (which can be detected on the third rising 
clock edge after T-j). To obtain an early indica- 
tion of an Interrupt Acknowledge cycle, the Shift 
register decodes an active FT in the presence of 
an inactive MREQ on the rising edge of T2. 

During an Interrupt Acknowledge cycle, the INTACK 
signal is generated on the rising edge of T2. 



Since it is the presence of INTACK and an active 
READ that gates the interrupt vector onto the data 
bus, the logic must also generate READ at the 
proper time. The timing parameter of concern here 
is TdlAi(RD) [INTACK to W (Acknowledge) Low 
Delay]. This time delay allows the interrupt 
daisy chain to settle so that the device 
requesting the interrupt can place its interrupt 
vector onto the data bus. The Shift register 
allows a sufficient time delay from the generation 
of INTACK before it generates READ. During this 
delay, it places the CPU into a Wait state until 
the valid interrupt vector can be placed onto the 
data bus. If the time between these two signals 
is insufficient for daisy chain settling, more 
time can be added by taking READ and WAIT from a 
later position on the Shift register. 

Figure 6 illustrates Interrupt Acknowledge cycle 
timing resulting from the Z80A CPU to Z8500 
peripheral and the Z80B CPU to Z8500A peripheral 
interface. This timing comes from the logic 
illustrated in Figure 5, which can be used for 
both interfaces. Should more Wait states be 
required, the additional time can be calculated in 
terms of system clocks, since the CPU clock and 
PCLK are the same. 
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Figure 6. Z80A/Z80B CPU to Z8500/Z8500A Peripheral Interrupt Acknowledge Interface Timing 



Z80H CPU to Z8500/Z8500A Peripherals 

Figure 7 depicts logic that can be used in inter- 
facing the Z80H CPU to the Z8500/Z8500A peripher- 
als. This logic is the same as that shown in 
Figure 5, except that a synchronizing flip-flop is 
used to recognize an Interrupt Acknowledge cycle. 
Since Z8500 peripherals do not rely upon PCLK 
except during Interrupt Acknowledge cycles, 
synchronization need occur only at that time. 
Since the CPU and the peripherals are running at 
different speeds, INTACK and "ED must be 
synchronized to the Z8500 peripherals clock. 

During I/O and normal memory access cycles, the 
synchronizing flip-flop and the Shift register 
remain cleared because the W signal is inactive. 
During opcode fetch cycles, the flip-flop and the 
Shift register again remain cleared, but this time 
because the MREQ signal is active. The synchro- 
nizing flip-flop allows an Interrupt Acknowledge 
cycle to be recognized on the rising edge of T2 
when W is active and MREQ is inactive, generating 
the INTA signal. When INTA is active, the Shift 
register can clock and generate INTACK to the 
peripheral and "WATT to the CPU. The Shift 
register delays the generation of READ to the 
peripheral until the daisy chain settles. The 



WAIT signal is removed when sufficient time has 
been allowed for the interrupt vector data to be 
valid. 

Figure 8a illustrates Interrupt Acknowledge cycle 
timing for the Z80H CPU to Z8500 peripheral inter- 
face. Figure 8b illustrates Interrupt Acknowledge 
cycle timing for the Z80H CPU to Z8500A peripheral 
interface. These timings result from the logic in 
Figure 7. Should more Wait states be required, 
the needed time should be calculated in terms of 
PCLKs, not CPU clocks. 



Z80 CPU to Z80 and Z8500 Peripherals 

In a Z80 system, a combination of Z80 peripherals 
and Z8500 peripherals can be used compatibly. 
While there is no restriction on the placement of 
the Z8500 peripherals in the daisy chain, it is 
recommended that they be placed early in the chain 
to minimize propagation delays during RET I cycles. 

During an Interrupt Acknowledge cycle, the IEO 
line from the Z8500 peripherals changes to reflect 
the interrupt status. Time should be allowed for 
this change to ripple through the remainder of the 
daisy chain before activating 10RQ 1 to the Z80 
peripherals, or READ to the Z8500 peripherals. 
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Figure 7. Z80H to Z8500/Z8500A Peripheral Interrupt Acknowledge Interface Logic 



During the RETI cycles, the IEO line from the 
Z8500 peripherals does not change state as in the 
Z80 peripherals. As long as the peripherals are 
at the top of the daisy chain, propagation delays 
are minimized. 

The logic necessary to create the control signals 
for both Z80 and Z8500 peripherals is shown in 



Figure 9. This logic delays the generation of 
10RQ 1 to the Z80 peripherals by the same amount of 
time necessary to generate READ for the Z8500 
peripherals. Timing for this logic during an 
Interrupt Acknowledge cycle is depicted in 
Figure 10. 
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Figure 8a. Z80H CPU to Z8500 Peripheral Interrupt Acknowledge Interface Timing 




Figure 8b. Z80H CPU to Z8500A Peripheral Interrupt Acknowledge Interface Tiaing 
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Figure 9. Z80 and Z85Q0 Peripheral Interrupt Acknowledge Interface Logic 




Figure 10. Z80 and Z8500 Peripheral Interrupt Acknowledge Interface Tining 



SOFTWARE CONSIDERATIONS — POLLED OPERATION 

There are several options available for servicing 
interrupts on the Z8500 peripherals. Since the 
vector or IP registers can be read at any time, 
software can be used to emulate the Z80 interrupt 



response. The interrupt vector read reflects the 
interrupt status condition even if the device is 
programmed to return a vector that does not 
reflect the status change (SAV or VIS is not 
set). The code below is a simple software routine 
that emulates the Z80 vector response operation. 



Z80 Vector Interrupt Response, Emulation by Software 

;This code emulates the Z80 vector interrupt 
joperation by reading the device interrupt 
; vector and forming an address from a vector 
;table. It then executes an indirect jump to 
;the interrupt service routine. 



INDX: LD A,C1VREG ; CURRENT INT. VECT. REG. 

OUT (CTRL), A ;WRITE REG. PTR. 

IN A, (CTRL) ; READ VECT. REG. 

INC A ;VALID VECTOR? 

RET Z ;N0 INT - RETURN 

AND 00001110B ;MASK OTHER BITS 

LD E,A 

LD D,0 ;F0RM INDEX VALUE 

LD HL,VECTAB 

ADD HL,DE ;ADD VECT. TABLE ADDR. 

LD A,(HL) ;GET LOW BYTE 

INC HL 

LD H,(HL) ;GET HIGH BYTE 

LD L, A ;F0RM ROUTINE ADDR. 

JP (HL) ;JUMP TO IT 

VECTAB: DEFW INT1 

DEFW 1NT2 

DEFW INT3 

DEFW INT4 

DEFW INT5 

DEFW INT6 

DEFW INT7 

DEFW INT8 
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A SIMPLE Z80-Z8500 SYSTEM 

The Z8500 devices interface easily to the Z80 CPU, 
thus providing a system of considerable flexi- 
bility. Figure 11 illustrates a simple system 
using the Z80A CPU and the Z8536 Counter/Timer and 
Parallel 1/0 Unit (CIO) in a mode 1 or non- 
interrupt environment. Since interrupt vectors 
are not used, the INTACK line is tied High and no 
additional logic is needed. Because the CIO can 



be used in a polled interrupt environment, the INT 
pin is connected to the CPU. The Z80 should not 
be set for mode 2 interrupts since the CIO will 
never place a vector onto the data bus. Instead, 
the CPU should be placed into mode 1 interrupt 
mode and a global interrupt service routine can 
poll the CIO to determine what caused the 
interrupt to occur. In this system, the software 
emulation procedure described above is effective. 
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Figure 11. Z80 to Z8500 Simple System Mode 1 Interrupt or Non-Interrupt Structure 



Additional Information - Zilog Publications 



1. 


Z80 


CPU 


Technical 


Manual 


(03-0029-01) 


7. 


Z80 Family Interrupt Structure 




2. 


Z80 DMA 


Technical 


Manual 


(00-201 3- AO) 




Tutorial 


(611-1809-0003) 


3. 


Z80 


PIO 


Technical 


Manual 


(03-0008-01) 


8. 


Z8530 SCC Technical Manual 


(00-2057-01) 


4. 


Z80 


CTC 


Technical 


Manual 


(03-0036-02) 


9. 


Z8536 CIO Technical Manual 


(00-2091-01) 


5. 


Z80 


SIO 


Technical 


Manual 


(03-3033-01) 


10. 


Z8038 FI0 Technical Manual 


(00-2051-01) 



6. Z80H CPU AC Characteristics (00-2293-01) 



7-23 



7-24 



Application Note 



the Z180 Interfaced 

WITH THE SCC AT 10 MHZ 



INTRODUCTION 

Build a simple system to prove and test the Z180 MPU 
interfacing the SCC at 10 MHz. 

This Application Note describes the design of a system 
using a Z801 80 MPU (Microprocessor Unit) and a Z85C30 
SCC (Serial Communications Controller), both running at 
10 MHz. Hereinafter, all references are to the Z180 
and SCC. 

The system board is a vehicle for demonstration and 
evaluation of the 1 MHz interface and includes the follow- 
ing parts: 

■ Z8018010VSC Z180 MPU 10 MHz, PLCC package 

■ Z85C3010VSC C-MOS Z8530 SCC Serial 
Communication Controller, 10 MHz, PLCC package 

■ 27C256EP-ROM 

■ 55257 Static RAM 

The Z1 80 is a Z80 compatible High Integration device with 
various peripherals on board. Using this device as an 
alternative to the Z80 CPU, reduces the number of parts 
and board space. However, processing speed and reli- 
ability increase. 

The serial communication devices on the Z180 are: two 
asynchronous channels and one clocked serial channel. 
This means handling synchronous serial communications 



protocols requires an off-chip "multi-protocol serial com- 
munication controller." The SCC is the ideal device to meet 
the requirements. 

Zilog's SCC is the multi-protocol (@ 10 MHz) universal 
serial communication controller which covers most serial 
communication applications including Monosync, Bisync 
and SDLC at 2.5M bits/sec speeds. Further, the wide 
acceptance of this device by the market ensures it is an 
"industrial standard" serial communication controller. Also, 
the Z180 has special numbers for system clock frequen- 
cies of 6. 1 44 - and 9.21 6 MHz which generate exact baud 
rates for on-chip asynchronous serial communication 
channels. This is due to the SCC's on-chip, 16-bit wide 
baud rate generator for asynchronous ASCI com- 
munications. 

The following 10 MHz interface explanation defines how 
the interrupt structure works. Also included is a discussion 
of the hardware and software considerations involved in 
running the system's communication board. This Appli- 
cation Note assumes the reader has a strong working 
knowledge of the Z180 and SCC; this is not a tutorial for 
each device. 

Note: All Signals with a preceding front slash, 7", are active 
Low, e.g.: B//W (WORD is active Low); /B/W (BYTE is 
active Low, only); /N//S (NORMAL and SYSTEM are both 
active Low). 
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INTERFACES 



The following subsections explain the interfaces 
between the: 

■ Z1 80 and Memory 

■ Z180 and I/O 

■ Z180andSCC 

Basic goals of this system design are: 

■ System clock up to 10 MHz 

■ UsingtheZ8018010VSC(Z18010MHzPLCCpackage) 
to take advantage of 1 M byte addressing space and 
compactness (DIP versions' addressing range is half; 
512Kbytes) 

■ Using Z85C3010VSC (CMOS SCC 10MHz PLCC 
package) 

■ Minimum parts count 

■ Worst case design 



■ Using EPLD for glue wherever possible 

■ Expandability 

The design method for EPLD is using TTLs (74HCT) and 
then translating them into EPLD logic. This design uses 
TTLs and EPLDs. With these goals in mind, the discussion 
begins with the Z180-to-memory interface. 

Z180 to Memory Interface 

The memory access cycle timing of the Z 180 is similar to 
the Z80 CPU memory access cycle timing. The three 
classifications are: 

■ Op-code fetch cycle (Figure 1) 

■ Memory read cycle (Figure 2) 

■ Memory write cycle (Figure 3) 

Table 1 shows the Z1 80's basic timing elements for the op- 
code's fetch/memory read/write cycle. 




Address 



/MREQ 
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Figure 1. Z180 Op-code Fetch Cycle Timing (One Wait State) 
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Table 1. Z8018010 Timing Parameters for Op-code Fetch Cycle (Worst Case: Z180 10 MHz) 



Mn 


oyiriDoi 


r arameier 


Min 


IvlaX 


1 Initc 


1 


tcyc 


Clock Cycle Period 


100 




ns 


2 


tCHW 


Clock Cycle High Width 


40 




ns 


3 


tCLW 


Clock Cycle Low Width 


40 




ns 


4 


tCT 


uiock hall I ime 




■4 r\ 
1U 


ns 


6 


tAD 


Clock High to Address Valid 




70 


ns 


8 


tMED1 


Clock Low to /MREQ Low 




50 


ns 


9 


tRDD1 


Clock Low to /RD Low 




50 


ns 




lAn 


Address Hold Time 


1U 




ns 


12 


tMED2 


Clock Low to /MREQ High 




50 


ns 


15 


tDRS 


Data to Clock Setup 


25 




ns 


16 


tDRH 


Data Read Hold Time 







ns 


22 


tWRD1 


Clock High to /WR Low 




50 


ns 


23 


tWDD 


Clock Low to Write Data Delay 




60 


ns 


24 


tWDS 


Write Data Setup to /WR Low 


15 




ns 


25 


tWRD2 


Clock Low to /WR High 




50 


ns 


26 


tWRP 


/WR Pulse Width 




110 


ns 


27 


tWDH 


/WR High to Data Hold Time 


10 




ns 



Note: 

Parameter numbers in this table are in the Z180 technical manual. 
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Figure 2. Z180 Memory Read Cycle Timing (One Wait State) 
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EP-ROM Interface 



During an Op-code fetch cycle, data sampling of the bus 
is on the rising PHI clock edge of T3 and on the falling edge 
of T3 during a memory read cycle. Op-code fetch cycle 
data sample timing is half a clock cycle earlier. Table 2 
shows how a memory read cycles' timing requirements are 
easier than an op-code fetch cycle by half a PHI cycle time. 



If the timing requirements for an Op-code fetch cycle meet 
specifications, the design satisfies the timing requirements 
for a memory read cycle. 

Table 2 has some equations for an op-code fetch, memory 
read/write cycle. 



Table 2. Parameter Equations (10 MHz) Op-code Fetch/Memory Read/Write Cycle 

Parameters Z1 80 Equation Value Units 

Address Valid to Data Valid (Op-code Fetch) 2(1+w)tcyc-tAD-tDRS 105+100wmin ns 

Address Valid to Data Valid (Memory Read 2(1+w)tcyc+tCHW+tcf-tAD-tDRS 155+100w min ns 

/MREQ Active to Data Valid (Op-code Fetch) (1+w)tcyc+tCLW-tMED1-tDRS 55+100w min ns 

/MREQ Active to Data Valid (Memory Read) (2+w)tcyc-tMED1-tDRS 105+100wmin ns~ 

/RD Active to Data Valid (Op-code Fetch) (1+w)tcyc+tCLW-tRRD1-tDRS 55+100w min ns 

/RD Active to Data Valid (Memory Read) (2+w)tcyc-tRRD1-tDRS 105+100w min ns 

Memory Write Cycle /WR Pulse Width tWRP+w*tcyc 110+1 OOw min ns 



Note: 

* w is the number of wait states. 



The propagation delay for the decoded address and gates 
in the previous calculation is zero. Hence, on the real 
design, subtracting another 20-30 ns to pay for propaga- 
tion delays, is possible. The 27C256 provides the EP-ROM 
for this board. Typical timing parameters for the 27C256 
are in Table 3. 

Table 3. EP-ROM (27C256) Key Timing Parameters 
(Values May Vary Depending On Mfg.) 

Access Time 
170ns 200ns 250ns 



Parameter 


Max 


Max 


Max 


Addr Access Time 


170 


200 


250 


/E to Data Valid 


170 


200 


250 


/OE to Data Valid 


75 


75 


100 



Note: 

Table 3 shows "Access Time" as applying /E to data valid. "/OE active to 
data valid" is shorter than "address access time". Hence, the interface 
logic for the EP-ROM is: Realize a 1 70ns or faster EPROM access time by 
adding one wait state (using the on-chip wait state generator of the Z 1 80). 
A 200ns requirement uses two wait states for memory access. 

SRAM Interface 

Table 4 has timing parameters for 256K bit SRAM for 
this design. 



Table 4. 256K SRAM Key Timing parameters 
(Values May Vary Depending On Mfg.) 





Access Time 




85nS 


100nS 


150nS 


Parameter 


Min 


Min 


Min 


Read Cycle: 








IE to Data Valid 


85 


100 


150 


/G to Data Valid 


45 


40 


60 


Write Cycle: 








Write Cycle Time 


85 


100 


150 


Addr Valid to End of Write 


75 


80 


100 


Chip Select to End of Write 


75 


80 


100 


Data Select to End of Write 


40 


40 


60 


Write Pulse Width 


60 


60 


90 


Addr Setup Time 












SRAM Read Cycle. An SRAM read cycle shares the 
same considerations as an EPROM interface. 



Like EPROM, SRAMs' "access time" applies /G to data 
valid, and 7E active to data valid" is shorter than "access 
time." This design allows the use of a 150ns access time 
SRAM by adding one wait state (using the on-chip wait 
state generator of the Z180). The circuit is common to the 
EPROM memory read cycle. 
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No wait states are necessary if there is a 85ns, or faster, 
access time by using SRAMs. Since the Z180 has on-chip 
MMU with 85ns or faster SRAM just copy the contents of 
EPROM (application program starts at logical address 
OOOOh) into SRAM after power on. Set up the MMU to SRAM 
area to override the EPROM area and stop inserting wait 
states. With this scheme, you can get the highest perfor- 
mance with moderate cost. 



SRAM Write Cycle. During a Z1 80 memory write cycle, the 
Z180 write data is stable before the falling edge of /WR 
(Z180 parameter #24; 15ns min at 10 MHz). It is stable 
throughout the write cycle (Z 1 80 parameter #27; 1 0nS min 
at 10 MHz). Further, the address is fixed before the falling 
edge of A/VR. As long as the /WR pulse width meets the 
SRAM's spec, there is no problem (reference Table 2). 
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Figure 3. Z180 Memory Write Cycle Timing (One Wait State) 



Memory Interface Logic 

The memory devices (EPROM and SRAM) for this design 
are 256K bit (32K byte). There are two possible memory 
interface designs: 

Connect Address Decode output to /E input. Put the signal 
generated by /RD and /MREQ ANDed together to /OE of 
EPROM and SRAM. Put the signal generated by /WR and 
/MREQ ANDed together to the /WE pin of SRAM 
(Figure 4a). 

Connect the signal Address ANDed together with inactive 
/IORQ to the /E input. Connect /RD to /OE of EPROM and 
SRAM, and /WR to /WE pin of SRAM (Figure 4b). 

Using the second method, there could be a narrow glitch 
on the signal to the /E-pin during I/O cycles and the 
Interrupt acknowledge cycle. During I/O cycles, /IORQ 
and /RD or /WR go active at almost the same time. Since 
the delay times of these signals are similar there is no 



"overlapping time" between /CE generated by the address 
(/IORQ inactive), and /WR or /RD active. During the Inter- 
rupt Acknowledge cycle, /WR and /RD signals are inactive. 

To keep the design simple and flexible, use the second 
method (Figure 4b). To expand memory, decode the 
address A15 NANDed with /USRRAM//USRROM and 
/IORQ to produce /CSRAM or /CSROM. These are chip 
select inputs to chips 55257 or 27C256, respectively. 
This either disables or enables on-board ROM or RAM 
depending upon selection control. 

The circuiton Figure 4b gives the physical memory address 
as shown on Figure 5. 

If there are no Z80 peripherals and /M1 is enabled (M 1 E bit 
in Z1 80 OMCR register set to 1 ), active wait states occur 
only during op-code fetch cycles (Figure 6). If the M1E bit 
is cleared to 0, /M1E is active only during the Interrupt 
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Acknowledge cycle and Return from Interrupt cycle. This 
case depends on the propagation delay of the address 
decoder which uses 135ns or faster EPROM assess time 



(assume there is 20ns propagation delay). Figure 6 shows 
the example of this implementation. 
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/WR To /WE Pin of 55257 



Figure 4A. Memory Interface Logic 



/USRROM > 



4.7K£2x2 




/CSRAM To 55257 /CE Pin 



/CSROM To 27C256 /CE Pin 



Figure 4B. Memory Interface Logic 
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Figure 6. Wait State Generator Logic 

(Extends Op-code Fetch Cycle Only; Not Working in Z 
Mode of Operation) 



Figure 5. Physical Memory Address Map 



Z180 TO I/O INTERFACE 

The Z180 I/O read/write cycle is similar to the Z80 CPU if 7 and 8). Table 5 shows the Z180 key parameters for an 
you clear the /IOC bit in the OMCR register to (Figures I/O cycle. 
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Figure 7. Z180 I/O Read Cycle Timing (/IOC = 0) 
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Figure 8. Z1 80 I/O Write Cycle Timing 



Table 5. Z8018010 Timing Parameters for I/O Cycle (Worst Case) 



No 


Symbol 


Parameter 


Min 


Max 


Units 


1 


tcyc 


Clock Cycle Period 


100 




ns 


2 


tCHW 


Clock Cycle High Width 


40 




ns 


3 


tCLW 


Clock Cycle Low Width 


40 




ns 


4 


tcf 


Clock Fall Time 




10 


ns 


6 


tAD 


Clock High to Address Valid 




70 


ns 


9 


tRDD1 


Clock High to /RD Low IOC=0 




55 


ns 


11 


tAH 


Address Hold Time 


10 




ns 


13 


tRDD2 


Clock Low to /RD High 




50 


ns 


15 


tDRS 


Data to Clock Setup 


25 




ns 


16 


tDRH 


Data Read Hold Time 







ns 


21 


tWDZ 


Clock High to Data Float Delay 




60 


ns 


22 


tWRD1 


Clock High to /WR Low 




50 


ns 


23 


tWDD 


Clock Low to Write Data Delay 




60 


ns 


24 


tWDS 


Write Data Setup to /WR Low 


15 




ns 


25 


tWRD2 


Clock Low to /WR High 




50 


ns 


26a 


tWRP 


/WR Pulse Width (I/O Write) 


210 




ns 


27 


tWDH 


/WR High to Data Hold Time 


10 




ns 


28 


tlOD1 


Clock High to /IORQ Low IOC=0 




55 


ns 


29 


tlOD2 


Clock Low to /IORQ High 




50 


ns 



Note: 

Parameter numbers in this table are the numbers in the Z180 technical manual. 
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If you are familiar with the Z80 CPU design, the same 
interfacing logic applies to the Z180 and I/O interface (see 
Figure 9a). This circuit generates /IORD (Read) or IORD 
(Write) for peripherals from inputs /IORQ, /RD, and /WR. 
The address decodes the Chip Select signal. Note, if you 
have Z80 peripherals, the decoder logic decodes only 
from addresses (does not have /IORQ). The Z180 signals 
/IORQ, /RD, and /WR are active at about the same time 
(Param #9, 22, 28). However, most of the Z80 peripherals 
require /CE to /RD or /WR setup time. 



Since the Z1 80 occupies 64 bytes of I/O addressing space 
for system control and on-chip peripherals, there are no 
overlapping I/O addresses for off-chip peripherals. In this 
design, leave the area as default or assign on-chip registers 
at I/O address OOOOh to 003Fh. 

Figure 9 shows a simple address decoder (the required 
interface signals, other than address decode outputs, are 
discussed later). 
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Chip Select Signals 
* for Peripherals 



/IORD To Each 
Peripherals' /RD 

/lOWRToEach 
Peripherals' /WR 



Figure 9A. I/O Interface Logic (Example) 




/csscc 

o SCC Interface Logic) 



HCT10 



Figure 9B. I/O Address Decoder for this Board 



When expanding this board to enable other peripherals, 
the decoded address A6/A7 is NANDed with USRIO to 
produce the Chip Enable (CSSCC) output signal (HC10). 
The SCC registers are assigned from address xxCOh to 
xxC3h; with image, they occupy xxCOh to xxFFh. To add 
wait states during I/O transactions, use the Z180 on-chip 
wait state generator instead of external hardware logic. 



If there is a Z80 PIO on board in a Z-mode of operation (that 
is, clear /M1 E in OMCR register to zero) and after enabling 
a Z80 PIO interrupt, zero is written to M1TE in the OMCR 
register. Without a zero, there is no interrupt from the Z80 
PIO. The Z80 PIO requires /M1 to activate an interrupt 
circuit after enabling interrupt by software. 
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Z180 TO SCC INTERFACE 



The following subsections discuss the various parameters 
between the Z180/SCC interface: CPU hardware, I/O op- 
eration (read/write), SCC interrupts, Z80 interrupt daisy- 
chain operation, SCC interrupt daisy-chain operation, I/O 
cycles. 

CPU Hardware Interfacing 

The hardware interface has three basic groups of signals: 
Data bus, system control, and interrupt control. For more 
detailed signal information, refer to Zilog's Technical 
Manuals, and Product Specifications for each device. 

Data Bus Signals 

D7-D0. Data bt/s(Bidirectional, 3-state). This bus transfers 
data between the Z1 80 and SCC. 

System Control Signals 

A//B, C//D. Register select signals(\rvput). These lines select 
the registers. 

/CE. Chip enable (Input, active low). /CE selects the proper 
peripheral for programming. /CE is gated with /IORQ or 
/MREQ to prevent false chip selects during other machine 
cycles. 

/RD+. /?eac/(input, active low). /RD activates the chip-read 
circuitry and gates data from the chip onto the data bus. 

/WR+. Write (Input, active low). /WR strobes data from the 
data bus into the peripheral. 

Chip reset occurs when /RD and /WR are active simulta- 
neously. 



Address 




Interrupt Control 

/INTACK. Interrupt Acknowledge (input, active low). This 
signal shows an Interrupt Acknowledge cycle which 
combines with /RD to gate the interrupt vector onto the 
data bus. 

/INT. Interrupt request (output, open-drain, active low). 

IEI. Interrupt Enable In (input, active high). 

IEO. Interrupt Enable Out (Output, active high). 

These lines control the interrupt daisy chain for the pe- 
ripheral interrupt response. 

SCC I/O Operation 

The SCC generates internal control signals from /RD or 
/WR. Since PCLK has no required phase relationship to 
/RDor/WR, the circuitry generating these signals provides 
time for meta stable conditions to disappear. 

The SCC starts the different operating modes by pro- 
gramming the internal registers. Accessing these internal 
registers occurs during I/O Read and Write cycles, de- 
scribed below. 

Read Cycle Timing 

Figure 1 illustrates the SCC Read cycle timing. All register 
addresses and /INTACK are stable throughout the cycle. 
The timing specification of SCC requires that the /CE signal 
(and address) be stable when /RD is active. 
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FigurelO. SCC Read Cycle Timing 
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Write Cycle Timing 

Figure 1 1 illustrates the SCC Write cycle timing. All register 
addresses and /INTACK are stable throughout the cycle. 
The timing specification of the SCC requires that the /CE 



signal (and address) be stable when /RD is active. Data is 
available to the SCC before the falling edge of /WR and 
remains active until /WR goes inactive. 
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Figure 11. SCC Write Cycle Timing 



SCC Interrupt Operation 

Understanding SCC interrupt operations requires a basic 
knowledge of the Interrupt Pending (IP) and Interrupt 
Under Service (IUS) bits in relation to the daisy chain. The 
Z180 and SCC design allow no additional interrupt re- 
quests during an Interrupt Acknowledge cycle. This per- 
mits the interrupt daisy chain to settle, ensuring proper 
response of the interrupt device. 

The IP bit sets in the SCC for CPU intervention require- 
ments (that is, buffer empty, character available, error 
detection, or status changes). The interrupt acknowledge 
cycle does not reset the IP bit. The IP bit clears by a 
software command to the SCC, or when the action that 
generated the interrupt ends, for example, reading a 
receive character for receive interrupt. Others are, writing 
data to the transmitter data register, issuing Reset Tx 
interrupt pending command for Tx buffer empty interrupt, 
etc.). After servicing the interrupt, other interrupts 
can occur. 

The IUS bit means the CPU is servicing an interrupt. The 
IUS bit sets during an Interrupt Acknowledge cycle if the IP 
bit sets and the IEI line is High. If the IEI line is low, the IUS 
bit is not set. This keeps the device from placing its vector 
onto the data bus. 



The IUS bit clears in the Z80 peripherals by decoding the 
RETI instruction. A software command also clears the IUS 
bit in the Z80 peripherals. Only software commands clear 
the IUS bit in the SCC. 

Z80 Interrupt Daisy-Chain Operation 

In the Z80 peripherals, both IP and IUS bits control the IEO 
line and the lower portion of the daisy chain. When a 
peripheral's IP bit sets, the IEO line goes low. This is true 
regardless of the state of the IEI line. Additionally, if the 
peripheral's IUS bit clears and its IEI line is High, the /INT 
line goes low. 

The Z80 peripherals sample for both /M1 and /IORQ active 
(and /RD inactive) to identify an Interrupt Acknowledge 
cycle. When /M1 goes active and /RD is inactive, the 
peripheral detects an Interrupt Acknowledge cycle and 
allows its interrupt daisy chain to settle. When the /IORQ 
line goes active with /M1 active, the highest priority inter- 
rupting peripheral places its interrupt vector onto the data 
bus. The IUS bit also sets to show that the peripheral is now 
under service. As long as the IUS bit sets, the IEO line 
remains low. This inhibits any lower priority devices from 
requesting an interrupt. 
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When the Z180 CPU executes the RETI instruction, the 
peripherals check the data bus and the highest priority 
device under service resets its I US bit. 

SCC Interrupt Daisy-Chain Operation 

In the SCC, the IUS bit normally controls the state of the IEO 
line. The IP bit affects the daisy chain only during an 
Interrupt Acknowledge cycle. Since the IP bit is normally 
not part of the SCC interrupt daisy chain, there is no need 
to decode the RETI instruction. To allow for control over the 
daisy chain, the SCC has a Disable Lower Chain (DLC) 
software command that pulls IEO low. This selectively 
deactivates parts of the daisy chain regardless of the 



interrupt status. Table 6 shows the truth table for the SCC 
interrupt daisy chain control signals during certain cycles. 
Table 7 shows the interrupt state diagram for the SCC. 

Table 6. SCC Daisy Chain Signal Truth Table 



During Idle State During INTACK Cycle 



IEI 


IP 


IUS 


IEO 


IEI 


IP 


IUS 


IEO 





X 


X 








X 


X 





1 


X 





1 


1 


1 


X 





1 


X 


1 





1 


X 


1 





1 








1 











Table 7. SCC Interrupt Status Diagram 

Interrupt Condition 



IP 
Set 



IEI High? 



INT 
Active 



Wait For CPU 
/INTACK Cycle 



/INTACK * IEI * /RD 



IUS 
Set 



CPU Read, Write, or Reset 



IP 
Cleared 



IEO High? 



IUS 
Cleared 



Return To Main Program 



The SCC uses /INTACK (Interrupt Acknowledge) for rec- 
ognition of an interrupt acknowledge cycle. This pin, used 
with /RD, allows the SCC to gate its interrupt vector onto the 
data bus. An active /RD signal during an interrupt acknowl- 
edge cycle performs two functions. First, it allows the 



highest priority device requesting an interrupt to place its 
vector on the data bus. Secondly, it sets the IUS bit in the 
highest priority device to show the device is now under 
service. 



INPUT/OUTPUT CYCLES 

Although the SCC is a universal design, certain timing 
parameters differ from the Z180 timing. The following 
subsections discuss the I/O interface for the Z180 MPU 
and SCC. 



Z1 80 MPU to SCC Interface 

Table 8 shows key parameters of the 10 MHz SCC for I/O 
read/write cycles. 
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Table 8. 10 MHz SCC Timing Parameters for I/O Read/Write Cycle (Worst Case) 


No 


Symbol 


Parameter 


Min 


Max 


Units 


b 


To A MA/D\ 
1 SA(WH) 


Address to /WR Low Setup 






ns 


•7 

1 


TK A MA/DN 


Aaaress to /wh Hign hoio 


U 




ns 


Q 
O 


ToA/DH\ 

1 SA(nU; 


Address to /RD Low Setup 


OU 




ns 


9 


ThA(RD) 


Address to /RD High Hold 







ns 


lb 


iSObl(WH) 


/Ob LOW tO /WH LOW be tup 







ns 


A -7 


Thr v C/\A/D\ 

1 nUb(Wn) 


/Ob to /wh High Hold 







ns 


iy 


1 SObl(HU) 


/Ub LOW tO /HD LOW betUp 


u 




ns 


nn 

Aj 


1 nOb(HL)) 


/ob to /HU Hign Hold 







ns 


22 


TwRDI 


/RD Low Width 


125 




ns 


25 


TdRDf(DR) 


/RD Low to Read Data Valid 




120 


ns 


27 


TdA(DR) 


Address to Read Data Valid 




180 


ns 


28 


TwWRI 


/WR Low Width 


125 




ns 


29 


TsDW(WR) 


Write Data to /WR Low Setup 


10 




ns 


30 


TdWR(W) 


Write Data to /WR High Hold 







ns 



SCC I/O Read/Write Cycle 

Assume that the Z180 MPU's /IOC bit in the OMCR (Op- 
eration Mode Control Register) clears to (this condition is 
a Z80 compatible timing mode for /IORQ and /RD). The 
following are several design points to consider (also see 
Table 3). 

I/O Read Cycle 

Parameters 8 and 9 mean that Address is stable 50ns 
before the falling edge of /RD and until /RD goes inactive. 

Parameters 1 9 and 20 mean that /CE is stable at the falling 
edge of /RD and until /RD goes inactive. 

Parameter 22 means the /RD pulse width is wider 
than 125ns. 

Parameters 25 and 27 mean that Read data is available on 
the data bus 120ns later than the falling edge of /RD and 
1 80ns from a stable Address. 



I/O Write Cycle 

Parameters 6 and 7 mean that Address is stable 50ns 
before the falling edge of /WR and is stable until /WR goes 
inactive. 

Parameters 1 6 and 1 7 mean that /CE is stable at the falling 
edge of /WR and is stable until /W goes inactive. 

Parameter 28 means /WR pulse width is wider than 1 25ns. 

Parameters 28 and 29 mean that Write data is on the data 
bus 1 0ns before the falling edge of /WR. It is stable until the 
rising edge of /WR. 

Tables 9 and 10 show the worst case SCC parameters 
calculating Z 180 parameters at 10 MHz. 
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Table 9. Parameter Equations Worst Case (Without Delay Signals - 


No Wait State) 




Ow 


71 an 






i di cii i it? id o 


Pni latinn 

L^V|UCUIvH 1 


value 


1 Initc 


t_ a /nn\ 
1 SA(HL)) 


tCyc-tAD+tHUL)1 


30 min 


ns 


1 Ur\\Ur\) 


Qfr>\/r«j.tr k W\A/j-tr'f tAH tHRQ 


^:4o min 


ns 




9tn\/p4-tPHW4-tnf tRDm tDR^ 

*llL/yv_»-rlA»yn VV+ lUI-lnLJL/ riuno 


1 fin min 
I OU 1 1 1 1 1 1 


ns 


TwRDI 


2tcyc+tCHW+tcf-tDRS+tRDD2 


185 min 


ns 


TsA(WR) 


tcyc-tAD+tWRD1 


30 min 


ns 


TsDW(WR) 


tWDS 


15 min 


ns 


TwWRI 


tWRP 


210 min 


ns 



Table 10. Parameter Equations 



Z180 SCC 
Parameters Equation 

tDRS Address 

3tcyc+tCHW-tAD-TdA(DR) 
RD 

2tcyc+tCHW-tRDD1-TdRD(DR) 



I/O Read Cycle 

These tables show that a delay of the falling edge of /RD 
satisfies the SCC TsA(RD) timing requirement of 50ns min. 
The Z180 calculated value is 30ns min for the worst case. 
Also, Z1 80 timing specification tAH (Address Hold time) is 
10ns min. The SCC timing parameters ThA(RD) {Address 
to /RD High Hold) and ThCE(RD) {/CE to /RD High Hold) 
are minimum at 0ns. The rising edge of /RD is early to 
guarantee these parameters when considering address 
decoders and gate propagation delays. 

I/O Write Cycle 

Delay the falling edge of /WR to satisfy the SCC TsA(/WR) 
timing requirement of 50ns min. TheZ180 calculates 30ns 



Value Units 



241 min ns 
184 min ns 



min worst case. Further, the Z1 80 timing specifications tAH 
(Address Hold time) and tWDH (/WR high to data hold 
time) are both 10ns min. The SCC timing parameters 
ThA(WR) {Address to /WR High Hold), ThCE(WR) {/CE to 
/WR High Hold) and TdWR(W) {Write data to /WR High 
hold) are a minimum of ns. The rising edge of /WR is early 
to guarantee these parameter requirements. 

This circuit depicts logic for the I/O interface and the 
Interrupt Acknowledge Interface for 10 MHz clock of 
operation. Figure 12 is the I/O read/write timing chart 
(discussions of timing considerations on the Interrupt 
Acknowledge cycle and the circuit using EPLD 
occur later). 
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/csscc 

/WR 



Internal 
/WAIT 
Input 



HCT74 



HCT164 



To 

85C30 
ICE 




To 

Z180 

/WAIT 



Figure 12. SCC I/O Read/Write Cycle Timing 



If you are running your system slower than 8 MHz, remove 
the HCT74, D-Flip/Flop in front of HCT164. Connect the 
inverted CSSCC to the HCT164 B input. This is a required 
Flip/Flop because the Z180 timing specification on tlOD1 
(Clock High to /IORQ Low, IOC=0) is maximum at 55ns. 
This is longer than half the PHI clock cycle. Sample it using 
the rising edge of clock, otherwise, HCT164 does not 
generate the same signals. 

The RESET signal feeds the SCC /RD and /WR through 
HCT27 and HCT02 to supply the hardware reset signal. To 
reduce the gate count, drop these gates and make the 
SCC reset by its software command. The SCC software 



reset - OCOh to Write Register 9, "Hardware Reset com- 
mand" has the same effect as hardware reset by 
"Hardware." 

Interrupt Acknowledge Cycle Timing 

The primary timing differences between the Z1 80 and SCC 
occur in the Interrupt Acknowledge cycle. The SCC timing 
parameters that are significant during Interrupt Acknowl- 
edge cycles are in Table 1 1 . The Z180 timing parameters 
are in Table 12. The reference numbers in Tables 1 1 and 
12 refer to Figure 14. 
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Table 1 1 . 10MHz SCC Timing Parameters for Interrupt Acknowledge Cycle 



No 


Symbol 


Parameter 


Min 


Max 


Units 


13 


TslAi(RD) 


/INTACK Low to /RD Low Setup 


130 




ns 


14 


ThlA(RD) 


/INTACK High to /RD High Hold 







ns 


15 


ThlA(PC) 


/INTACK to PCLK High Hold 


30 




ns 


38 


TwRDA 


/INTACK Low to /RD Low Delay 


125 




ns 






(Acknowledge) 








39 


TwRDA 


/RD (Acknowledge) Width 


125 




ns 


40 


TdRDA(DR) 


/RD Low (Acknowledge) to 




120 


ns 






Read Data Valid Delay 








41 


TslEI(RDA) 


I El to /RD Low (Acknowledge) 


95 




ns 






Setup Time 








42 


ThlEI(RDA) 


I El to /RD High (Acknowledge) 







ns 






Hold Time 








43 


TdlEI(IEO) 


IEI to IEO Delay 




175 


ns 



Table 12. Z180 Timing Parameters Interrupt Acknowledge Cycles (Worst Case Z180) 



No 


Symbol 


Parameter 


Min 


Max 


Units 


10 


tM1D1 


Clock High to /M1 Low 




60 


ns 


14 


tM1D2 


Clock High to /M1 High 




60 


ns 


15 


tDRS 


Data to Clock Setup 


25 




ns 


16 


tDRH 


Data Read Hold Time 







ns 


28 


tlOD1 


Clock LOW to /IORQ Low 




50 


ns 


29 


tlOD2 


Clock LOW to /IORQ High 




50 


ns 


30 


tlOD3 


/M1 Low to /IORQ Low Delay 


200 




ns 



Note: 

Parameter numbers in this table are the numbers in the Z180 technical manual. 



During an Interrupt Acknowledge cycle, the SCC requires 
both /INTACK and /RD to be active at certain times. Since 
the Z180 does not issue either /INTACK or /RD, external 
logic generates these signals. 

The Z180 is in a Wait condition until the vector is valid. 
If there are other peripherals added to the interrupt priority 
daisy chain, more Wait states may be necessary to give it 
time to settle. Allow enough time between /INTACK active 
and /RD active for the entire daisy chain to settle. 



There is no need of decoding the RETI instruction used by 
the Z80 peripherals since the SCC daisy chain does not 
use IP, except during Interrupt Acknowledge. The SCC 
and other Z8500 peripherals have commands that reset 
the individual I US flag. 

External Interface for Interrupt Acknowledge Cycle: The 
bottom half of Figure 13 is the interface logic for the 
Interrupt Acknowledge cycle. 
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T2 



Tw 



/IORQ 



HCT164/CLR 



-0- 



X 



100 ns 



-0 — — ►{ 70 ns max 



20 ns max ■ 



HCT164Q1 



/RD (or, /WR) 



RD* Q1 
•SCCSEL 



/SCCRD/[(RD* 
/Q1*SCCSEL) 
+ RESET] 



Data (RD) 



/SCCWR 



Data (RD) 



\ 



A 



20 ns max 



■CZEZZX 



< 



■ 15 ns max 

■ 30 ns ( > ns) 

200 ns typ. ( > 125 ns)- 



4-<ji) 10nsmin 



A 



Valid Data 



k-©15nsmin 
SCC |« @ 210 n 



10 ns max - 




20 ns max 



■ 55 ns max 



' 15 ns max 
- > ns 



> 



A 



> 



*-@ ns min 
«-@ >0ns 



Figure 13. Z180 to SCC Interface Logic (Example) 
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The primary chip in this logic is the Shift register (HCT1 64), 
which generates /INTACK, /SCCRD and /WAIT. During I/O 
and normal memory access cycles, the Shift Register 
(HCT164) remains cleared because the /M1 signal is 
inactive during the op-code fetch cycle. Since the Shift 
Register output is Low, control of /SCCRD and /WAIT is by 



other system logic and gated through the NOR gate 
(HCT27). During I/O and normal memory access cycles, 
/SCCRD and /SCCWR are generated from the system /RD 
and /WR signals, respectively. The generation is by the 
logic at the top of Figure 1 4. 



LiuiJLnjLnjmjTjT^^ 



/M1 



/IORQ 



/INTACK 



/WAIT 



/SCCRD 



VECTOR 




'WA 



'WA 



'WA 



' WA T3 




50 ns max 



60 ns max I*-®-*- 




50 ns max @- 



/ 



\ 



scc 



sec 



120 ns max 



« (in- 



valid Data 




> 



>25 ns 



SCC 



Figure 14. SCC Interrupt Acknowledge Cycle Timing 
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Normally, an Interrupt Acknowledge cycle appears from 
the Z1 80 during /M1 and /IORQ active (which is detected 
on the third rising edge of PHI after T1 ). To get an early sign 
of an Interrupt Acknowledge cycle, the Shift register de- 
codes an active /M1. This is during the presence of an 
inactive /MREQ on the rising edge of T2. 

During an Interrupt Acknowledge cycle, the /INTACK 
signal is generated on the rising edge of 12. Since it is the 
presence of /INTACK and an active SCCRD that gates the 
interrupt vector onto the data bus, the logic also generates 
/SCCRD at the proper time. The timing parameter of 
concern here is TdlAi(RD) [/INTACK to/RD (Acknowledge) 



Low delay]. This time delay allows the interrupt daisy chain 
to settle so the device requesting the interrupt places its 
interrupt vector onto the data bus. 

The Shift Register allows enough time delay from the 
generation of /INTACK before it generates /SCCRD. Dur- 
ing this delay, it places the Z180 into a Wait state until the 
valid interrupt vector is placed onto the data bus. If the time 
between these two signals is not enough for daisy chain 
settling, more time is added by taking /SCCRD and /WAIT 
from a later position on the Shift Register. If there is a 
requirement for more wait states, the time is calculated by 
PHI cycles. 



USING EPLD 

Figure 15a and Figure 15b show the logic using either gate logic to EPLD is to disassemble MSIs' logic into SSI 
EPLDorthecircuitofthissystem.TheEPLDisALTERA610 level, and then simplify the logic, 
which is a 24-Pin EPLD. The method to convert random 
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MREQS23 



XWAIT@5 



PIN OUT 
INP 



PIN OUT 



M1814 



PIN OUT 



2 X OUT 

AND2 



•NOHF 1 



n Q 



OUT _ BNOR2y 




IACK@18 



WAIT@17 



NORF 1 



3 



ZILOG Z180-SCC 
12/3/88 BUSLOGIC 
EPLDt EP610 OFF 



•-C MREQ 

•-C IORQ 

•-C RD 

•-C MR 

•— cue 

•-c sec 

•-C CLK 

XWAIT 
*-C RESET 



SCCRD >-• 
SCCWR >-• 
INTACK >-• 



Figure 15a. EPLD Circuit Implementation 



AO 


DO 


Al 


Dl 


A2 


D2 


A3 


D3 


A4 


D4 


A5 


D5 


A6 


D6 


A7 


D7 


AB 




A9 




AlO 




All 




A12 




A13 




A14 




W 




CE 




OE 









.1 " 

= 8 = 


.i - 

1 8 = 


.1 - 

- 8 = 


.1 - 

= %- 


.1 - 

= 8 = 


.1 - 

= 6 = 


.i - 

= 8 = 


M. 

220F 


1 O 1 Pn on 
GND | 















GND 1 




2 XRESET 


IEI 3 


-□ O 


4 IEO 


USRROM 5 


-o o- 


6 USRRAH 


USRIO 7 


-o o- 
-o o 


B A19 


INTACK 9 




10 XWAIT 




-o o- 





TXDA 1 


-□ O 


2 RXDA 


RTSA 3 


-o oJ 


4 SYKCA 


TXCA 5 


-o o~ 


6 RXCA 


DCDA 7 




8 CTSA 


W-REQA 9 


-o o- 
-o o 


10 DTR-RQA 


DREQO 11 




12 DREQ1 


REQB 13 


-o o 


14 DTR-ROB 


TXDB 15 


-o o 
-o o- 


16 RXDB 


RTSB 17 


-o o 


18 SYNCB 


TXCB 19 




20 RXCB 


DCDB 21 


-o o- 


22 CTSB 


* 


-o o- 
-0 o- 
-0 o 


f 



P3 



mo l 




2 RXAO 


TDl 3 


-a o- 
-o o 


4 RD1 


TXDB 5 




6 RXDB 


GND 7 


-o o 


8 DCDO 


RTSO > tl 


-o o- 
-o o- 


10 GND 




12 CTSO 


TD2 13 


-o o- 
-o o 


14 RD2 


RTSB 15 




16 CTSB 




-o o 
-o o 
-0 o- 


f 



GND 1 




2 CLK 


x-3_ 
Z£ 
WAIT 7 


-□ O- 

-o o 


4 RD 




6 WR 


-o o 


8 Ml 


BACK 9 


o o 
-0 o- 


10 E 


BREQ 11 




12 MREQ 


RESET 13 


-o o 


14 ZORO 


NHI 15 


-o o- 


16 RFSH 


INTO 17 


-o o- 
-o o- 


18 HALT 


INT1 19 


-o o- 


20TEND1 


INT2 21 




22DREQ1 


ST 23 


-o o- 
-o o- 


24 CXS 


AO 25 




26 RXS 


Al 27 


-o o- 


28 TXS 


A2 29 


-o o- 


30 CKA1 


A3 31 


-o o 


32 RXA1 


A4 33 


-o o 
-o o 


34 TXA1 


A5 35 




36DREQ0 


A6 37 


-o o 


38 RXAO 


A7 39 


-o o- 


40 TXAO 


A8 41 


-o o- 


42 DCDO 


A9 43 


-o o 


44 CTSO 


AlO 45 


-o o 


46 RTSO 


All 47 


-o o- 


48 D7 


A12 49 


-o o- 


50 D6 


A14 > §3" 


-o o- 


52 D5 


-o o- 


54 D4 


A15 55 


-0 o- 


56 D3 


A16 57 


-o o- 


58 D2 


A17 59 


-0 o 


60 Dl 


A18 61 


-o o 


62 DO 


VCC 63 


-o o- 


64 GND 




-o o 





Figure 15b. EPLD Circuit implementation 



System Checkout 



SCC Write Cycle Proof 



After completion of the board (PC board or wire wrapped 
board, etc.), the following methods verify that the board is 
working. 

Software Considerations 

Based on the previous discussion, it is necessary to 
program the Z180 internal registers, as follows, before 
system checkout: 

■ Z80 mode of operation - Clear /M1E bit in OMCR 
register to zero (to provide expansion for Z80 
peripherals). 

■ Z80 compatible mode - Clear IOC bit in OMCR register 
to zero. 

■ Put one wait state in memory cycle, and no wait state 
for I/O cycle DMCR register bits 7 and 6 to " 1 " and bits 
5 and 4 to "0". 

SCC Read Cycle Proof 

Read cycle checking is first because it is the simplest 
operation. The SCC Read cycle is checked by reading the 
bits in RRO. First, the SCC is hardware reset by simulta- 
neously pulling /RD and /WR LOW (The circuit above 
includes the circuit for this). Then, reading out the Read 
Register returns: 

D7-D0 = 01xxx100b 

BitD2, D6:1 

BitD7,D1,D0:0 

Bit D5: Reflects /CTS pin 

Bit D4: Reflects /SYNC 

Bit D3: Reflects /DCD pin 



Write cycle checking involves writing to a register and 
reading back the results to the registers which return the 
written value. The Time Constant registers (WR12 and 
WR 1 3) and External/Status Interrupt Enable register (WR 1 5) 
are on the SCC. 

Interrupt Acknowledge Cycle 

Checking an Interrupt Acknowledge (/INTACK) cycle 
consists of several steps. First, the SCC makes an Interrupt 
Request (/INT) to the Z1 80. When the processor is ready to 
service the interrupt, it shows an Interrupt Acknowledge 
(/INTACK) cycle. The SCC then puts an 8-bit vector on the 
bus and the Z1 80 uses that vector to get the correct service 
routine. The following test checks the simplest case. 

First, load the Interrupt Vector Register (WR2) with a 
vector, disable the Vector Interrupt Status (VIS) and enable 
interrupts (IE=1 , MIE=1 IEI=1). Disabling VIS guarantees 
only one vector on the bus. The address of the service 
routine corresponding to the 8-bit vector number loads the 
Z1 80 vector table, and the Z1 80 is under Interrupt Mode 2. 

Because the user cannot set the SCC I nterrupt Pending Bit 
(IP), setting an interrupt sequence is difficult. An interrupt 
is generated indirectly via the CTS pin by enabling the 
following explanation. 

Enable interrupt by /CTS (WR15, 20h), External/Status 
Interrupt Enable (WR1, 01 h), and Master Interrupt Enable 
(WR9, 08h). Any change on the /CTS pin begins the 
interrupt sequence. The interrupt is re-enabled by Reset 
External/Status Interrupt (WRO, 10h) and Reset Highest 
IUS (WRO, 38h). 

A sample program of an SCC Interrupt Test is shown in 
Table 1 3. The following programs in Tables 1 3, 1 4, and 1 5 
assume that the 180 is correctly initialized. Table 13 uses 
the Assembler for the Z80 CPU. 
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Table 13. SCC Test Program - Interrupt for 180/SCC Application Board (Under Mode2 Interrupt) 



B register returns status info: 
Bit DO : current /cts stat 
D1set : /cts int received 



.z800 



Include 180macro.lib 

;SCC Registers 

scc_ad: 
scc_ac: 
scc_bd: 
scc_bc: 

scc_a: 



;Read in Z180 register names and 
;macro for Z180 new instructions 



scc_cont: 
scc_cont: 

inttest: 



wait_loop: 
wait_here: 



if 

else 
endif 



equ 
equ 
equ 
equ 

equ 



scc_a 
equ 

equ 



org 

Id 

Id 

Id 

im 

call 

Id 

ei 

bit 
jr 



0C3h 
0C2h 
0C1h 
OCOh 

OOOh 



scc_ac 
scc_bc 

09000h 

sp,top_of_sp 

a. high sccvect and Offh 
i,a 

2 

initscc 

b, 



1,b 

z.waitjoop 



subroutine to initialize sec registers 
initialization table format is 

register number, then followed by the data to be written 
;and the register number is Offh, then return 



initscc: 
initO: 



Id 

Id 

cp 

ret 

out 



hl.scctab 
a.(hl) 
Offh 
z 

(scc_cont),a 



;addrof sec eh a -data 
;addr of sec ch a - control 
;addr of sec ch b - data 
;addr of sec ch b - control 

;set Offh to test ch a 
;clear OOh to test ch b. 



;top of user ram area 

;init sp 
;init i reg 

;set interrupt mode 2 
•.initialize sec 
;clear status 
;enable interrupt 

;check int status 
;if not, loop again 

;interrupt has been received 
;ou can set breakpoint here! 



;initializ sec 

;get register number 

; reached at the end of table? 

;yes, return. 

; write it 



inc 

Id 

out 

inc 

jr 



hi 

a,(hl) 

(scc_cont),a 
hi 

initO 



; point to next data 

;get the data to be written 

;write it 

;point to next data 
;then loop 



; external/status interrupt service routine 



ext_stat: 



Id 



a,10h 

out 

in 

and 

rra 

rra 

rra 

rra 

rra 

set 

Id 

Id 

out 

ei 

ret 



(scc_cont),a 
a,(scc_cont) 
00100000b 



1.a 
b,a 

a,38h 

(scc_cont),a 



reset ext/stat int 
read stat 

mask off bits other than /cts 
shift into DO loc 



;set interrupt flag 
;save it 

;reset highest ius 
;enable int 
; return from int 



; initialization data table for sec 

;table format - register number, then value for the register 
;and ends with Offh - since sec doesn't have 
register Offh... 



scctab: 





db 


09h 


;select WR9 


if 


sec a 








db 


10000000b 


;ch a reset 


else 










db 


01000000b 


;ch b reset 


endif 










db 


Oeh 


;selectWR15 




db 


20h 


;only enable /cts int 




db 


01h 


;select WR1 




db 


00000001b 


;enable ext/stat int 




db 


10h 


; reset ext/stat int 




db 


10h 


;twice 




db 


09h 


;select WR9 




db 


08h 


;mie, vect not incl. stat 




db 


Offh 


;end of table 



interrupt vector table 
sccvect: 



org 
dw 



inttest + 100h 
ext_stat 



top_of_sp: 



.block 
end 



100h 



; reserve area for stack 
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Table 14 shows a "macro" to enable the Z180 to use the chip DMA. The SCC self loop-back test transfers data 
Z80 Assembler, as well as register definitions. using the Z180 DMA at the highest transmission rate 

(Table 14). 

There is one good test to ensure proper function. Generate 
a data transfer between the Z180/SCC using the Z180 on- 
Table 14. Program Example - Z180 CPU Macro Instructions 

File name - 1 80macro.lib 
;* Macro library for Z180 new instructions for asm800 



;Z180 System Control Registers 



;ASCI Registers 



cntlaO: 


equ 


OOh 


ASCI Cont Reg A ChO 


cntlal: 


equ 


01h 


ASCI Cont Reg A Ch1 


cntlbO: 


equ 


02h 


ASCI Cont Ren B ChO 


cntlbl: 


equ 


03h 


ASCI Cont Reg B Ch1 


statO: 


equ 


04h 


ASCI Stat Reg ChO 


statl: 


equ 


05h 


ASCI Stat Reg Ch1 


tdrO: 


equ 


06h 


ASCI Tx Data Reg ChO 


tdrl: 


equ 


07h 


ASCI Tx Data Reg Ch1 


rdrO: 


equ 


08h 


ASCI Rx Data Reg ChO 


rdrl: 


equ 


09h 


ASCI Rx Data Reg Ch1 


;CSI/0 Registers 






cntr: 


equ 


Oah 


CSI/O Cont Reg 


trdr: 


equ 


Obh 


CSI/O Tx/Rx Data Reg 


;Timer Registers 






tmdrOI: 


equ 


Och 


Timer Data Reg ChO-low 


tmdrOh: 


equ 


Odh 


Timer Data Reg ChO-high 


rldrOI: 


equ 


Oeh 


Timer Reload Reg ChO-low 


rldrOh: 


equ 


Ofh 


Timer Reload Reg ChO-high 


tcr: 


equ 


10h 


Timer Cont Reg 


tmdrll: 


equ 


14h 


Timer Data reg Ch 1 -low 


tmdrlh: 


equ 


15h 


Timer Data Reg Ch 1 -high 


rldMI: 


equ 


16h 


Timer Reload Reg Ch1-low 


rldrlh: 


equ 


17h 


Timer Reload Reg Ch1-high 


frc: 


equ 


18h 


Free Running Counter 


;DMA Registers 






sarOI: 


equ 


20h 


DMA Source Addr Reg ChO-low 


sarOh: 


equ 


21h 


DMA Source Addr Reg ChO-high 


sarOb: 


equ 


22h 


DMA Source Addr Reg ChO-b 


darOI: 


equ 


23h 


DMA Dist Addr Reg ChO-low 


darOh: 


equ 


24h 


DMA Dist Addr Reg ChO-high 


darOb: 


equ 


25h 


DMA Dist Addr Reg ChO-B 


bcrOI: 


equ 


26h 


DMA Byte Count Reg ChO-low 


bcrOh: 


equ 


27h 


DMA Byte Count Reg ChO-high 


marll: 


equ 


28h 


DMA Memory Addr Reg Ch1-low 


marlh: 


equ 


29h 


DMA Memory Addr Reg Ch1-high 


marlb: 


equ 


2ah 


DMA Memory Addr Reg Ch1-b 


iarll: 


equ 


2bh 


DMA I/O Addr Reg Ch1 -low 


iarlh: 


equ 


2ch 


DMA I/O Addr Reg Ch1-high 
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bcrll: 


equ 


2eh 


; DMA Byte uount Heg Lnl 


-low 


hr>r1 h- 

UCrl I II. 


GQU 


9fh 
C.W I 


• HK/IA R\/to Pni int Ron r*h1 
, L/IVI/A Dylfc; V^UUIIl Hey Ul I I 


-high 


dstat: 


equ 


30h 


; DMA Stat Reg 




dmode: 


equ 


31h 


; DMA Mode Reg 




dcntl: 


equ 


32h 


; DMA/WAIT Control Reg 





; System Control Registers 



il: equ 33h 

itc: equ 34h 

rcr: equ 36h 

cbr equ 38h 

bbr: equ 39h 

cbar: equ 3ah 

omcr: equ 3eh 

icr: equ 3fh 



INT Vector Low Reg 
INT/TRAP Cont Reg 
Refresh Cont Reg 
MMU Common Base Reg 
MMU Bank Base Reg 
MMU Common/Bank Area Reg 
Operation Mode Control Reg 
I/O Control Reg 



?b 


equ 





?c 


equ 


1 


?d 


equ 


2 


?e 


equ 


3 


?h 


equ 


4 


?l 


equ 


5 


?a 


equ 


7 


??bc 


equ 





??de 


equ 


1 


??hl 


equ 


2 


??sp 


equ 


3 



sip macro 

db 11101101B 
db 01110110B 
endm 



mlt macro ?r 

db 11101101B 

db 01 001 1 00B+(7?&?r AND 3) SHL 4 

endm 



inO 



macro 
db 
db 
db 

endm 



?r, ?p 

11101101B 

00000000B+(?&?r AND 7) SHL 3 
?P 



outO 



macro 
db 
db 
db 

endm 



?p, ?r 
11101101B 

00000001 B+(?&?r AND 7) SHL 3 
?P 



otim macro 

db 11101101B 
db 1000001 1B 

endm 
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otimr 



macro 

db 

db 

endm 



11101101B 
10010011B 



otdm 



macro 

db 

db 

endm 



11101101B 
1000101 1B 



otdmr 



macro 

db 

db 

endm 



11101101B 
10011011B 



tstio 



macro 
db 
db 
db 

endm 



?P 

11101101B 
01110100B 
?P 



tst 



macro 

db 

ifidn 

else 
ifdef 

else 



endif 
endif 
endm 
.list 



?r 

11101101B 
<?r>,<(hl)> 
db 

?&?r 
db 

db 
db 



00110100B 



000001 00B+(?&?r AND 7) SHL 3 

01100100B 
?r 



end 
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Table 15 lists a program example for the Z180/SCC DMA 
transfer test. 



Table 15. Test Program - Z180/SCC DMA Transfer 



; * Test program for 1 80 DM A/SCC 

;* Test 180's DMA function with SCC 

;* 1 80 dma - dmaO for sec rx data 

;* dmal for sec txdata 

;* async, X1 mode, 1 stop, speed = pclk/4 

;* self loop-back 

;* Connect W/REQ to DREQO0M8O 

;* DTR/REQ to DREQ1 of 180 

;* B register returns status info: 

;* Bit DO set : Tx DMA end 

;* D1 set : Rx DMA end 

;* D2 set : Data doesn't match 



.z800 



Include 180macro.lib 
;SCC Registers 



scc_ad 
scc_ac 
scc_bd 
scc_bc 

scc_a: 



scc_cont: 
scc_data: 

else 

scc_cont: 
scc_data: 



length: 



sccdma: 



endif 



equ 
equ 
equ 
equ 

equ 

scc_a 

equ 

equ 

equ 
equ 



equ 

org 

Id 
Id 
Id 
Id 

outO 



0C3h 
0C2h 
0C1h 
OCOh 

OOh 



scc_ac 
scc_ad 

scc_bc 
scc_bd 



1000h 

09000h 

sp,tx_buff 

a,(highz180vect) and Offh 
i,a 

a,00h 
(il).a 



;Read in Z180 register names and 
; macro for Z180 new instructions 



addr of sec eh a - data 
addr of sec ch a - control 
addr of sec ch b - data 
addr of sec ch b - control 

;if test ch. a, set this to Offh 
;for ch.b, set this to OOh 



transfer length 

;top of user ram area 

;init sp 
;init i reg 

;init il 
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im 


2 


;Set interrupt mode 2 




call 


fill mpm 

1 III 1 1 ICI 1 1 


•initipli7P tv/rv hiiffpr arpp 

,11 1111011^.0 IA/IA LSUIIC7I Cll CCl 




call 


initscc 


initialize sec 




call 


initdma 






Id 


b,0 


■init ^tatu^ 

1 11 111 oiuiuo 




Id 


a.OOh 


;load 1st data to be sent 




out 


\OV_»L> Uctld/,cl 






Id 


a,1 1001 100b 


;enable dmac and int from DMAO 




outO 


(dstat).a 






Id 


a,05h 


.Oddsl VWI I \J 




out 


(scc_cont),a 






Id 




•Qtart ty 
.oidi 1 lA 




out 


(scc_cont),a 






Gi 




•\A/Jiit hprp for pnmnlptinn 

, wan 1 it/ic iui i-»ui i ipicuui i 


loop: 


bit 


1.b 


;rx dma end? 




K 


z.loop 


;not, then loop again 




push 


be 


;save be reg 




Id 


be, length 


;compare tx data with rx data 




Id 


de,tx_buff 






Id 


hl,rx_buff 




chkloop: Id 


a,(de) 








cpi 








J'r 


nz,bad_data 






jp 


v.good 






inc 


de 






jr 


chkloop 




had data - 

vjcakj \j a ic* • 


nnn 
pup 


be 


TPQtorP hr* 




set 


2.b 


;set error flag 




jr 


enddma 




good: 


pop 


be 


; restore be 


enddma: 


jr 


$ 


;tx/rx completed 








;you can put breakpoint here 


filljnem: | 


d 


hl.temp 


; prepare data to be sent 




Id 


bc.length 


; set length 




Id 


de,tx_buff 






Id 


(hl).OOh 




filljoop: 


Idi 








in 


nv fill 00 

1 1 V | 1 1 1 1 \J\J 






dec 


hi 






inc 


(hi) 






jr 


filljoop 




filLOO: 


Id 


bc.length 


; clear rx buffer area to zero 




Id 


de,rx_buff 






Id 


(hl).OOh 




filLOOl: 


Idi 








ret 


nv 
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initscc: 
initO: 



dec 
jr 

Id 

Id 

cp 

ret 

out 

inc 

Id 

out 

inc 



hi 

filLOOl 

hl.scctab 

a,(hl) 

Offh 

z 

(scc_cont),a 
hi 

a.(hl) 

(scc_cont),a 
hi 

initO 



; initializa sec 



;intjalize z180's sec 



Inltdma: 



Id 
Id 
Id 

otimr 
Id 

outO 
Id 

outO 



ret 



hl.addrtab 
c.sarOI 

b.dstat- sarOI 

a,00001100b 
(dmode),a 
a,01001000b 
(dcntl).a 



; initialize DMA 



;dmacO - i/o to mem++ 

1 mem wait, no i/o wait, 
EDGE trigger, mem ++ to i/o 
should be EDGE for Tx DMA 
NOT level 

- because of DTR/REQ timing 



txend: Id a,00010100b ;isr for dmal int-complete tx 

outO (dstat).a ;disabledma1 

set O.b ;set status 

ei 
ret 



rxend: Id a,00100000b ;isr for dmaO int 

outO (dstat).a ;disable dmaO 

set 1,b ; set status 

ei 
ret 



; initialization data table for sec 

itable format - register number, then value for the register 
;and ends with Offh - since sec doesn't have 
register Offh... 





db 


09h 


;select WR9 


if scc_a 










db 


10000000b 


; reset eh a 


else 










db 


01000000b 


;ResetChB 


endif 










db 


04h 


;select WR4 




db 


00000100b 


;async,x1 ,1stop,parity off 
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db 
db 

db 
db 

db 
db 

db 
db 

db 
db 

db 
db 

db 
db 

db 
db 

db 
db 



01 h 

01100000b 

02h 
OOh 

03h 

11000000b 
05h 

01100000b 

06h 
OOh 

07h 
OOh 

09h 

00000001b 
Oah 

00000000b 
Obh 

01010110b 


1010 
110 



select WR1 
REQ on Rx 

select WR2 

OOh as vector base 

select WR3 
Rx 8bit/char 

select WR5 
tx 8bit/char 

select WR6 



selecl WR7 



select WR9 
stat low, vis 

select WR10 
set as default 

select WR11 

No xtal 

TxC.RxC from BRG 
TRxC = BRG output 



db 
db 



Och 
OOh 



;select WR12 
;BR TC Low 



db 
db 



Odh 
OOh 



;select WR12 
;BRTChigh 



db 
db 



Oeh 

00010110b 
000 

1 



1 

1 




;select WR14 

nothing about DPLL 
Local loopback 
No local echo 
DTR/REQ is req 
BRG source = PCLK 
Not enabling BRG yet 



db 
db 



Oeh 

00010111b 
000 
1 


1 

1 
1 



;select WR14 

nothing about DPLL 
Local loopback 
No local echo 
DTR/REQ is REQ 
BRG source = PCLK 
Enable BRG 



db 
db 



03h 

11000001b 



;select WR3 
;rx enable 
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db 
db 

db 
db 

db 
db 

db 
db 

db 
db 

db 

;source/dist addr table for Z180's dma 



addrtab: 



; interrupt vector table 
z180vect: 



db 
db 
db 

dw 
db 

dw 

dw 
db 

db 
db 

db 

dw 



org 

.block 

.block 

.block 

.block 

dw 

dw 

.block 

.block 

.block 



01h 

11100000b 
Ofh 

00000000b 

10h 
10h 

01h 

11100000b 
09h 

00001001b 
Offh 



scc_data 

OOh 

OOh 

rx_buff 
OOh 

length 

tx_buff+1 
OOh 

scc_data 
OOh 

OOh 

length-1 



sccdma + 200h 

2 

2 

2 

2 

rxend 

txend 

2 

2 

2 



;select WR1 
;enable DMA 

;selectWR15 

;don't use any of ext/stat int 
; reset ext/stat twice 



;selectWR1 
;no int 

;selsct WR9 
;enable int 

;end of table 



;dmacO source 

;dmacO dist 

;byte count 
;mar 

;iar 

;dummy! 
;byte count 



180 int1 vect 00000 
180 int2 vect 00010 
180 prtO vect 00100 
180 prt1 vect 00110 
180dmac0 vect 01000 
180 dmad vect 01010 
180 csi/ovect 01100 
180 asciO vect 01 110 
180 ascM vect 10000 



tx_buff: 
rx_buff: 
temp: 



org 
.block 
.block 
.block 



sccdma + 1000h 

length 

length 

1 



end 
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First, this program (Table 15) initializes the SCC by: 

Async, X1 mode, 8-bit 1 stop, Non-parity. 

Tx and Rx clock from BRG, and BRG set to 

PCLKRSelf Loopback 

Then, it initializes 4K bytes of memory with a repeating 
pattern beginning with OOh and increases by one to FFh 
(uses this as Tx buffer area). Also, it begins another 4K 
bytes of memory as a Rx buffer with all zeros. After starting, 
DMA initialization follows: 

DMACO: For Rx data transfer: I/O to Mem, Source address- 
fixed.Destination address-increasing. Edge sense mode: 
Interrupt on end of transfer. 



DMAC1 : For Tx data transfer: Mem to I/O, Source address- 
increasing, Destination address- fixed. Edge sense mode: 
Interrupt on end of transfer. 

Now, start sending with DMA. 

On completion of the transfer, the Z1 80 DMAC1 generates 
an interrupt. Then, wait for the interrupt from DMACO which 
shows an end of receive. Now, compare received data 
with sent data. If the transfer was successful (source data 
matched with destination), OOh is left in the accumulator. If 
not successful, OFFh is left in the accumulator. 

This program example specifies a way to initialize the SCC 
and the Z1 80 DMA. 



CONCLUSION 

This Application Note describes only one example of 
implementation, but gives you an idea of how to design the 
system using the Z180 and SCC. 



For further design assistance, a completed board together 
with the Debug/Monitor program and the listed sample 
program are available. If interested, please contact your 
local Zilog sales office. 
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THE ZlLOG DATACOM FAMILY WITH THE 80186 CPU 



Z Hog's newdatacom family evaluation board features the 801 86 along with four multiprotocol serial 
controllers, and allows customers to evaluate these components in an Intel environment 



INTRODUCTION 

Zilog's customers need a way to evaluate its serial 
communications controllers with a central CPU. This App 
Note (Application Note) explains and illustrates how the 
datacom family interfaces and communicates with the 
80186 on this evaluation board. The board helps the 
potential customer to evaluate Zilog's data communications 
controllers in an Intel environment. 



The most advanced and complex component of the serial 
family is the IUSC. One of the highlights of this App Note is 
how the IUSC adapts to the 801 86 CPU with a minimum of 
difficulty and a maximum of bus and functional flexibility. 



GENERAL DESCRIPTION 

The evaluation board includes the following hardware. 
(Reference two page Schematic diagram at rear of the 
App Note - Figures 5A and 5B.) 

■ Intel 80186 Integrated 16-bit Microprocessor 

■ Zilog Z16C32 Integrated Universal Serial Controller 
(IUSC) 

■ Zilog Z1 6C33 Monochannel Universal Serial Controller 
(MUSC) or USC 

■ Zilog Z16C35 Integrated Serial Communications 
Controller (ISCC) 

■ Zilog Z85230 Enhanced Serial Communications 
Controller (ESCC) or SCC 

■ Two 28-pin EPROM sockets, suitable for 2764*s through 
2751 2's 

■ Six 32-pin (or 28-pin) SRAM sockets, suitable for 
32Kx8 or 1 28Kx8 devices 



■ Four Altera EPLD circuits comprising the glue logic 
(Figures 1-4 at rear of the App Note) and Evaluation 
Board Schematic (Figures 5a, 5b). 

■ RS-232 and RS-422 line drivers and receivers 

■ Pin headers for configuring and interconnecting the 
above to serial applications 

Notes: 

All Signals with a preceding front slash, 7", are active Low, e.g.: 
B//W (WORD is active Low); /B/W (BYTE is active Low, only). 



Power connections follow conventional descriptions below: 



Connection 


Circuit 


Device 


Power 


V C c 




Ground 


GND 


^SS 
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Processor 



The 80186 may be operated at rates up to 1 6 MHz. To use 
the CPU clock for accurate serial bit clocking, a 9.8304 
MHz CPU clock can be used. The crystal connected to the 
processor is 2X the operating frequency. 

The processor's 1 Mbyte address space is well filled if the 
maximum RAM complement is installed. Of the integrated 
Chip Select outputs provided by the 80186, the /UCS 
output is used for the EPROMs, and all of the /PCSO-6 
outputs are used for the datacom controllers. A hardware 
address decoder is used for the SRAMs instead of the 
80186's /LCS and /MCSO-3 outputs because the RAMs 
must be accessible to the on-chip DMA functions of the 
ISCC and IUSC as well as the 801 86. The 801 86 does not 
decode addresses from external bus masters. Both 8- and 
16-bit accesses are provided for RAM. The EPROMs are 
only accessible to the 80186. 

The 80186's mid-range memory chip select feature 
(specifically, the /MCS2 output) is used to give the software 
a way to hardware Reset the ISCC, IUSC, and (M)USC. 



This allows a customer's program to operate as if it were in 
a target system starting from Reset, including the initial 
write to the Bus Configuration Register (BCR). 

The 801 86's two integrated DMA channels can be used for 
any two of the four or six serial data streams in the B side 
of the (E)SCC and the (M)USC. The "DMA EPLD" derives 
requests for the 80186's two DMA channels from six 
inputs, two each for (E)SCC channel B and the one or two 
channels in the (M)USC. It asserts DREQ0 or DREQ1 
(High) if any of the inputs for that channel is low, and the 
80186 is not performing an Interrupt Acknowledge cycle. 
Jumper blocks J22, J23, J24 and J29 control the assignment 
of the 801 86's internal DMA controllers, including provision 
for a clipped Tx request that is needed if a standard SCC 
is installed in place of the ESCC. The various possibilities 
are summarized in Table 1 . 



Table 1. 80186 DMA Jumper Connections 



To enable the following to use 801 86 DMA Channel 0: Install this jumper: 

(E)SCCBRx J23-1 toJ23-2 

MUSC Rx or USC A Rx J22-1 to J22-2 

MUSC Tx or USC A Tx J22-4 to J22-2 

USC B Rx J29-1 to J29-2 

USC B Tx J29-4 to J29-2 



To enable the following to use 80186 DMA Channel 1 : 



Install this Jumper: 



ESCC B Tx 

(E)SCC B Tx w/early release 

MUSC Rx or USC A Rx 

MUSCTxorUSCATx 

USCBRx 

USCBTx 



J24-1 to J24-3 
J24-1 toJ24-2 
J22-1 to J22-3 
J22-4 to J22-3 
J29-1 to J29-3 
J29-4 to J29-3 



If more than one channel among the ESCC B and (M)USC 
are enabled for one of the 801 86's internal DMA channels, 
software must ensure that only one of the enabled devices 
makes requests during a given block transfer. This can be 
done by leaving an entire Receiver or Transmitter idle or 
disabled, or by programming the device so that the DMA 
request is not output on the pin. 



The ISCC and IUSC handle their own DMA transfers via the 
80186's HOLD/HLDA facility. 

Note: Either a Z16C33 MUSC or a Z16C30 USC can be 
installed in socket U5. If this is done, references to the 
(M)USC herein after may mean the USC as a whole or just 
its channel A; which one should be clear from the context. 
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The inputs and outputs associated with the processor's 
integrated counter/timer facility are brought to the pin 
header labelled J26 sothatthey can be used in applications 
(Table 2). 



Table 2. Counter/Timer Signal Locations 



J26 pin 


Signal 


1 


Timer In 1 


2 


Timer Out 1 


3 


Timer In 


4 


Timer Out 


5 


NC 


6 


Ground 



The 80186's integrated interrupt controller is largely 
bypassed in favor of the traditional Zilogical interrupt 
daisy-chain structure. 



Push buttons are provided for Reset and Non-Maskable 
Interrupt (NMI). A means to generate an NMI, in response 
to a Start bit received from the user's PC or terminal, is also 
provided. The first transmitted Start bit on the RS-232 



Console connector J1, after a Reset, also produces an 
NMI; this feature can be used to find which serial controller 
channel is connected to the Console connector. 

Address Map 

EPROM is located at the highest addresses, and its size is 
programmable in the 80186 for the /UCS output. The 
addresses of the datacom controllers are programmed in 
the 801 86 for the /PCSO-6 outputs, as a block of 1 28x7=896 
bytes starting at a 1 Kbyte boundary. The block can be in 
I/O space or in a part of memory space that is not used for 
SRAM or EPROM. The starting 1 Kbyte boundary is called 
(PBA) in the following sections. 

RAM extends upward from address 0. 

Using 128Kx8 SRAMs and 64Kx8 EPROMs, the address 
map might be as shown in Table 3. 



Table 3. Suggested Address Map 



RAM 00000-BFFFF 

(E)SCC D8000, 2, 4, 6 or D8000-D803E (even addrs only) 

ISCC D8080-D80FE (even addrs only) 

(M)USC D8100-D81FF 

IUSC D8200-D837F 

ISCC-IUSC-(M)USC Reset DB000-DB7FF (if enabled) 

2751 2 EPROM E0000-FFFFF 



EPROM 

Two 28-pin EPROM sockets are provided; both must be 
populated in order to handle the 801 86's 1 6-bit instruction 
fetches. Jumper header J18 allows the sockets to be 
compatible with 2764s, 27128s, 27256s, or 27512s; it is 
jumpered at the factory to match the EPROMs provided. 
For 27512s only, jumper J18-2 to J18-3 and leave J18-1 
open. For 2764s, 27128s, or 27256s, jumper J 18-2 to J 18- 
1 and leave J 18-3 open. 

Note: J18 connects pin 1 of both sockets to either A16 or 
Vcc. This is done because for 2764s, 271 28s, and 27256s, 
pin 1 is Vpp which may require a high voltage and/or draw 
more current than a normal logic input. For 2764s and 



27128s, a similar jumper might be provided in some 
designs for pin 27 (/PGM). As long as the address for /UCS 
is programmed as described in the next paragraph, A15 
(which is connected to pin 27) is high whenever /UCS is 
low, so that 2764s and 27128s operate correctly. 

The first code executed after Reset should program the 
801 86's Chip Select Control Registers to set up the address 
ranges for which outputs like /UCS and /PCSO-6 are 
asserted. In particular, the UMCS register (address A0H 
within the 801 86's Peripheral Control Block) must be 
programmed to correspond to the size of EPROMs used 
(Table 4). 
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EPROM (Continued) 



Table 4. EPROM Address Ranges 

EPROM type UMCS value EPROM Address Range 



2764 


FC3C 


FCOOO-FFFFF 


27128 


F83C 


F8000-hhhhh 


27256 


F03C 


F0000-FFFFF 


27512 


E03C 


EOOOO-FFFFF 



The three LSBs of the above UMCS values are all 100, 
which signifies no external Ready/WAIT is used and no 
wait states are required. If the EPROMs are not fast enough 
for no-wait-state operation, making the three LSBs 101, 
1 1 0, or 1 1 1 extends EPROM cycles by 1 , 2, or 3 wait states, 
respectively. 



RAM 

Six 32-pin sockets are provided; they should be populated 
in pairs, starting with the lower-numbered sockets, to allow 
for 1 6-bit accesses. Vcc is provided at both pin 32 and pin 
30 so that 28-pin 32Kx8 SRAMs can be installed in pins 



3-30 of the sockets. Jumper block J1 9 allows decoding of 
the Chip Select signals from A17-16 for 32Kx8 SRAMs or 
from A1 9-1 8 for 1 28Kx8 SRAMs. The six standard memory 
populations are: 



One pair of 32Kx8 devices: 
Two pairs of 32Kx8 devices: 
Three pairs of 32Kx8 devices: 
One pair of 128Kx8 devices: 
Two pairs of 128Kx8 devices: 
Three pairs of 128Kx8 devices: 



64Kbytes at 00000-0FFFF 
128Kbytes at 00000-1 FFFF 
192Kbytesat00000-2FFFF 
256Kbytes at 00000-3FFFF 
512Kbytes at 00000-7FFFF 
768Kbytes at 00000-BFFFF 



J19 is factory set according to the size of the SRAMs 
provided. For 32Kx8 SRAMs, jumpers are installed between 
J 19-2 and J 19-3, and between J 19-5 and J 19-6, with J 19- 
1 and J19-4 left open. For 128Kx8 SRAMs, jumpers are 
installed between J 19-1 and J 19-2, and between J 19-4 
and J 19-5, with J 19-3 and J 19-6 left open. 

32Kx8 SRAMs have cyclic/redundant addressing starting 
at 40000, 80000, and C0000. The only configuration in 
which this causes problems is with three pairs of 32Kx8 
SRAMs and 275 1 2 EPROMs; in this case, there is a conflict 
in the range E0000-EFFFF. This conflict can be avoided by 
any of the following means: 

■ Using two pairs of 32Kx8 SRAMs; 

■ Using one pair of 1 28Kx8 SRAMs; 

■ Using 27256 EPROMs, or 

■ Using 27512 EPROMs but programming the size of 
/UCS like they are 27256s. 



Since the /LCS output of the 80186 is not used, the LMCS 
register in the 80186 is not written with any value. 

Programming the Peripheral Chip Selects 
The 80186 allows the /PCSO-6 pins, which in this case 
select the various datacom controllers, to be asserted for 
a selected 896-byte block of addresses. The block may 
reside in either memory or I/O space depending on the 
values programmed into the PACS and MPCS registers, 
locations A4H and A8H of the 80186's Peripheral Control 
Block, respectively. The choice of address space depends 
on the needs of the customer's application and the 
configuration of software supplied with the board 
(Table 5). 
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Table 5. Three Standard Alternatives for Serial Controller Addressing 



Basic Requirement Base Address (PBA) PACS value MPCS value 

I/O Space 8000 0838 81 B8 

Memory Space, 32Kx8 SRAMS used .38000 3838 81 F8 

Memory Space, 128Kx8SRAMs used D8000 D838 81 F8 



The three LSBs of the PACS value specify the Ready/WAIT 
handling for the /PCSO-3 lines which select the (E)SCC, 
ISCC, and (M)USC. The three LSBs of the MPCS value 
specify the Ready/WAIT handling for the /PCS4, 5, and 6 
lines, which select the IUSC. Both fields are shown here 
with the LSB's 000, signifying that the 801 86 should honor 
a WAIT on the external Ready/WAIT signal, but that it 
should not provide any minimum wait. 

Programming the Mid-Range Memory to Reset the ISCC, 
IUSC, and (M)USC 

A Reset puts the ISCC, IUSC, and (M)USC in a special and 
unique state in which the first write to each device implicitly 
goes to a Bus Configuration Register (BCR) that controls 
the device's basic bus operation; the BCR is not accessible 
thereafter. So that this board can serve as a complete 



development environment for customers' software, it 
includes a means whereby software (e.g., the debug 
monitor) can assert the /RESET input of these three devices. 
Specifically, assertion of the /MCS2 output of the 80186 
causes such a Reset. 

The 81 in the MS Byte of the MPCS values, shown in Table 
5, makes each of the /MCSO-3 pins correspond to a 2 
Kbyte block of addresses in memory space. The actual 
active pin addresses are determined by the value written 
into the MMCS register; location A6H of the 80186' 
Peripheral Control Block. Table 6 shows suggested MMCS 
values as a function of the RAM chip size, and the 
corresponding range of addresses for which any read or 
write access causes the three controllers to be reset. 



Table 6. Address Ranges for Reset 







Address Range for which ISCC, 


RAM Size 


MMCS value 


IUSC, and (M)USC are Reset: 


32Kx8 


3BFF 


3B000-3B7FF 


128Kx8 


DBFF 


DB000-DB7FF 



The three LSBs of the above MMCS values are 1 1 1 so that Interrupt Daisy Chain (Priority) Order 

the longest possible Reset pulse is generated when any of Jumper block J25 selects whether the (E)SCC device is at 

the locations in the indicated range are accessed. the start or the end of the interrupt daisy chain. 



Note that if this feature is not needed, it can be disabled by 
simply not programming the MMCS register. 



To make the interrupt priority be: 
(E)SCC highest, IUSC, ISCC, (M)USC lowest 
IUSC highest, ISCC, MUSC, (E)SCC lowest 
IUSC highest, ISCC, USC, (E)SCC lowest 



Jumper J25 as follows: 

J25-2 to J25-3, J25-4 to J25-5 (J25-1, J25X open) 
J25-1 to J25-2, J25-3 to J25-4 (J25-5, J25X open) 
J25X to J25-2, J25-3 to J25-4 (J25-1 , J25-5 open) 



This variability is provided in part because early versions 
of the 85230 ESCC had trouble passing an interrupt 
acknowledge down the daisy chain if it occurred in response 



to a lower-priority device's request just as the 
ESCC was starting to make its own request. Current 
85230's don't have the problem. 



7-63 



(E)SCC 



Socket U2 can be configured for either an ESCC or SCC, 
and for versions thereof that use either multiplexed or non- 
multiplexed address and data. Jumper blocks J20 and J21 
select certain signals accordingly. For a part with 
multiplexed addresses and data (80x30), jumper J20-1 to 
J20-2 and leave J20-3 open, and jumper J21-1 to J21-2 
and J21-4 to J21-5, leaving J21-3 and J21-6 open. With 
such a part, software can directly address the (E)SCC's 
registers, and need not concern itself with writing register 
addresses to Write Register (WRO). 

For a part having a non-multiplexed bus (85x30), jumper 
J20-2 to J20-3, J21 -2 to J21 -3, and J21 -5 to J21 -6, leaving 
J20-1 , J21 -1 , and J21-4 open. In this case, software must 
handle the (E)SCC by writing register addresses into its 
WRO in order to access any register other than WRO, RRO, 
or the data registers. 

Channels A and B can be handled on a polled or interrupt- 
driven basis. Channel A of the (E)SCC is suggested for 
connecting the user's PC or terminal for use with the Debug 
Monitor included in this evaluation kit. Channel B (but not 
A) can be handled on a DMA basis using the 80186's 
internal DMA channels, or on a polled or interrupt driven 
basis. 

Jumper block J23 allows channel B's /W//REQB output to 
be used for either a Wait function or a Receive DMA 
Request function. To use the output for Wait, jumper 
J23-2 to J23-3 and leave J23-1 open. The Wait function is 
only significant if the software wants to delay completion of 
a Read from the (E)SCC's Receive Data register until data 
is available, and/or if it wants to delay completion of a Write 
to the Transmit Data register until the previously-written 
character has been transferred to the Transmit Shift register. 
These modes are alternatives to checking the 
corresponding status flags and can be used to achieve 
operating speeds higher than those possible with such 
traditional polling, although not as fast as the speeds 
possible with a DMA approach. 

To use the /W//REQB output as a Receive DMA Request, 
jumper J23-1 to J23-2 and leave J23-3 open. 

Jumper block J24 determines how channel B's /DTR// 
REQB output is used. To use this output for the Data 



(PBA), (PBA)+8, ... (PBA)+120 
(PBA)+2, +10, ...(PBA)+122 
(PBA)+4, +12, ...(PBAJ+124 
(PBA)+6, +14, ...(PBA)+126 



Terminal Ready function , jumper J24-3 to J24-4 and leave 
J24-1 and J24-2 open. To use this output directly as a 
Transmit DMA Request (using the ESCC's early-release 
capability), jumper J24-1 to J24-3 and leave J24-2 and 
J24-4 open. To drive the Transmit DMA Request with a 
clipped version of this signal that is forced High earlier than 
a standard SCC drives it High, jumper J24-1 to J24-2 and 
leave J24-3 and J24-4 open. 

The "SCC EPLD" handles the (E)SCC's signalling 
requirements. Among other things, this EPLD configures 
the (E)SCC socket's pins 35 and 36 for either a multiplexed 
or non-multiplexed part, based on whether J20 is jumpered 
to connect the 80186 ALE signal to one of its input pins. If 
the device detects high-going pulses on this input, it drives 
corresponding low-going Address Strobe pulses onto 
(E)SCC pin 35 and drives low-going Data Strobe pulses 
onto (E)SCC pin 36. 

If the SCC EPLD's pin 9 stays at Ground, the part drives 
Read strobes onto pin 36 and drives delayed Write strobes 
onto pin 35, for a non-multiplexed 85x30 device. 

While the ESCC's relaxed timing capability allows the 
80186's /WR output to be connected directly to the /WR 
input of a non-multiplexed ESCC, the SCC EPLD delays 
start of an SCC's write cycle until write data is valid, even 
though this is not necessary for an ESCC. 

The SCC EPLD also generates the clipped-DMA-request 
signal mentioned in connection with J24, and logically ORs 
Reset onto pins 35 and 36. The device also tracks the two 
IACK cycles provided by the 80186 for each Interrupt 
Acknowledge cycle. For a multiplexed address/data port, 
it drives the address strobe (only) on the first cycle, and it 
provides the /RD or /DS pulse needed by the (E)SCC (only) 
on the second cycle. The "DMA EPLD" provides the 
INTACK signal needed by the (E)SCC. 

The (E)SCC is only accessible at even addresses. For a 
non-multiplexed part (85x30), the following four register 
locations are repeated throughout the even addresses 
from (PBA) through (PBA)+ 126: 



Channel B Command/Status register 
Channel B Data register 
Channel A Command/Status register 
Channel A Data register 
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For a multiplexed part (80x30), the Select Shift Left basic (E)SCC register map occurs twice in the even 
command (D1-0=11) should be written to Channel B's addresses from (PBA) through (PBA)+ 126: 
WRO before any other registers are accessed. Then the 



(PBA), (PBA)+2, ... (PBA)+30 
(PBA)+32, +34, ... (PBA)+62 
(PBA)+64, +66, ... (PBA)+94 
(PBA)+96, +98, ...(PBA)+126 



Channel B registers 0-15 
Channel A registers 0-15 
Channel B registers 0-15 
Channel A registers 0-15 



The redundant addressing of the (E)SCC is used to control 
a feature that can be used by software to allow the user to 
interrupt software execution from his keyboard. If the 
(E)SCCisreadatan ad dress with A6-5=1 1 (for a multiplexed 
part this means in the higher-addressed A channel), a 
mode is set in which a low on the console Received Data 
line (i.e., a Start bit on pin 3 of the J1 connector) 



causes a Non-Maskable Interrupt on the 801 86. The mode 
is cleared by Reset, or when the (E)SCC is read at an 
address with A6-5= 1 (on a multiplexed part, in the higher- 
addressed B channel). The NMI handler should do the 
latter fairly quickly to prevent subsequent data bits on 
Received Data from causing further NMIs. 



ISCC 

Since the 801 86 processor provides multiplexed addresses 
and data, the ISCC is configured to use the addresses on 
the AD lines. Therefore, software can address the various 
ISCC registers directly, and need not be concerned with 
writing register addresses into the indirect address fields 
of the ISCC's WRO and CCAR. 

Because the ISCC includes four DMA channels, its Channel 
A and B Transmitters and Receivers can be handled on a 
polled, interrupt-driven, and/or DMA basis, in any mixture. 

Since the ISCC can only be programmed as an 8-bit 
device on the AD7-0 lines, it occupies only the even- 
addressed bytes within its address range, (PBA)+128 
through (PBA)+254. 

The first write to this address range, after a Reset, implicitly 
writes the ISCC's Bus Configuration Register (BCR). To 
match up with the rest of the board's hardware, this first 
write should be a byte write that stores the hexadecimal 
value C6 in any even address in the first half of the ISCC's 
address range [(PBA)+ 128 through (PBA)+190]. Details 
of this transaction are as follows: 

■ The High induced by a pull-up resistor on the ISCC's 
A/B input selects the WAIT protocol on the /WAIT//RDY 
pin, which corresponds to how the 80186 works. (In 
subsequent register accesses, the A/B selection is 
taken from A5 of the multiplexed address.) 



■ A Low on the ISCC's SCC//DMA input, which is 
connected to A6, is required by the internal logic of the 
ISCC. This is why the BCR write is restricted to the first 
half of the ISCC's address range. 

■ As with all transactions between the 801 86 and ISCC, 
the address must be even because the ISCC only 
accepts slave-mode data on the AD7-0 pins. 

■ The MSB of the data (D7) is 1 to enable the Byte Swap 
feature, so that when the ISCC's DMA controller is 
reading transmit data from RAM, it takes alternate 
bytes from AD7-0 and AD 15-8. 

■ D6 of the data is 1 so that when the ISCC's DMA 
controller is reading transmit data from RAM, it takes 
even-addressed bytes from D7-0 and odd-addressed 
bytes from D15-8 (same function as the 80186). 

■ D2-1 of the data are 1 1 to select double-pulsed mode 
for the ISCC's /INTACK input. Again, this is how the 
80186 works. 

■ DO of the data is to select Shift Left Address mode so 
that the ISCC subsequently takes register addressing 
from the AD5-1 lines rather than from AD4-0. This is 
because the 80186 is a 16-bit processor that locates 
even-addressed bytes on AD7-0 and odd-addressed 
bytes on AD15-8, but the ISCC only accepts slave- 
mode writes on the AD7-0 pins. 
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ISCC (Continued) 



■ The fact that the ISCC's internal logic sees activity on Given that the BCR is written as above, the ISCC's slave- 
its /AS pin, which is inverted from the 80186' ALE mode address map is as follows: 
signal, automatically conditions it for a multiplexed 
Address/Data bus. 



(PBA)+128, 130 (PBA)+190 DMA Controller Registers 

(PBA)+192, 194, .... (PBA)+222 ISCC Serial Channel B registers 0-15 

(PBA)+224, 226 (PBA)+254 ISCC Serial Channel A registers 0-15 



(M)USC 

Since the 801 86 processor provides multiplexed addresses 
and data, the (M)USC is configured to use the addresses 
on the AD lines. Therefore, the software need not write 
register addresses into the indirect address field of the 
(M)USC's CCAR. 

The (M)USC's Transmitter and Receiver can be handled 
on a polled or interrupt-driven basis. In addition, any two of 
the Receivers and Transmitters in the (M)USC and Channel 
B of the (E)SCC can be handled on a DMA basis, using the 
80186's integrated DMA controllers. 

Jumper block J22 connects the (M)USC's /RxREQ and 
/TxREQ outputs to the "DMA EPLD" that makes the DMA 
Requests to the 80186. As shipped from the factory, 
jumpers are installed between J22-1 and J22-2, and 
between J22-3 and J22-4. In this configuration, the 
(M)USC's /RxREQ drives the 80186 DREQ0, and (M)USC 
/TxREQ drives the 80186 DREQ1. To reverse this 
assignment, jumper J22-1 to J22-3 and J22-2 to J22-4. To 
disconnect the (M)USC from one or both of the 80186's 
DMA channels, remove one or both jumpers (put them in 
a safe place in case you change your mind). Jumper block 
J29 provides the same connection-variability for the 
/RxREQ and /TxREQ outputs of Channel B of a USC. 

Since the 801 86's DMA channels are not capable of fly-by 
operation, the (M)USC's /RxACK and /TxACK pins have no 
dedicated function. They can be used for Request to Send 
and Data Terminal Ready; the two signals are lightly pulled 
up since they are not driven after Reset. 

The (M)USC can be programmed using 1 6-bit data on the 
AD15-0 lines or 8-bit data on AD15-8 and AD7-0. It makes 
the distinction between 8- and 16-bit operations as part of 
its address map rather than via a control input. The PS pin 
of an MUSC, or the A//B pin of a USC, is connected to a 
latched version of 80186 A7. The D//C pin of the (M)USC 
is grounded. The overall address range of the (M)USC is 
256 bytes, between (PBA)+256 and (PBA)+51 1 . 



The first write to this address range, after a Reset, implicitly 
writes the (M)USC's Bus Configuration Register (BCR). To 
match the rest of the board's hardware, this first write 
should be a 1 6-bit write, storing the hex value 0007 at any 
address in the second half of the (M)USC's range [any 
address in (PBA)+384 through 510, i.e., in the A channel 
of a USC]. Details of this transaction are as follows: 

■ The High on the PS or A//B input, which is connected 
to A7, selects the WAIT protocol on the /WAIT//RDY 
pin, corresponding to how the 80186 works. 

■ The MSB of the data (D15) is because a separate 
non-multiplexed address is not wired to pins AD13:8 
ofthe(M)USC. 

■ Bits 1 4-3 are required to be all zeros by the (M)USC's 
internal logic. 

■ D2 of the data is 1 to tell the (M)USC that the data bus 
is 16 bits wide. 

■ D1 of the data is 1 to select double-pulsed mode for 
the (M)USC's /INTACK input. This is how the 80186 
works. 

■ DO of the data is 1 to select Shift Right Address mode 
so that the (M)USC subsequently takes register 
addressing from the AD6-0 lines rather than from 
AD7-1. 

■ The fact that the (M)USC's internal logic sees activity 
on its /AS pin, which is inverted from the 80186' ALE 
signal, automatically conditions it for a multiplexed 
Address/Data bus. 
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Given that the BCR is written as above, the (M)USC 
address map is as follows: 



Starting Addr 


Ending Addr 


Registers Accessed 


(PBA)+256 
(PBA)+320 
(PBA)+384 
(PBA)+448 


(PBA)+319 
(PBA)+383 
(PBA)+447 
(PBA)+511 


16-bit access to MUSC regs or USC channel B regs 
8-bit access to MUSC regs or USC channel B regs 
16-bit access to MUSC regs or USC channel A regs 
8-bit access to MUSC regs or USC channel A regs 



Note: 

To maximize compatibility, program an MUSC using the second half of this range, (PBA)+384 through (PBA)+51 1 . 



While the ESCC and ISCC can drive their Baud Rate pins7of J9, J10, and J1 2, at which point it can be jumpered 
Generators from their PCLK inputs, the (M)USC has no to pin 9 or 8 so that it is routed to the /TxC or /RxC pin of the 
such input. The 801 86 clock output SYSCLK is brought to device. 



IUSC 

Since the 801 86 processor provides multiplexed addresses 
and data on the AD lines, the IUSC is configured to use 
these addresses. Software need not write register 
addresses into the indirect address fields of the lUSC's 
CCAR and DCAR. 

The lUSC's two DMA channels allow its Receiver and 
Transmitter to be handled on a polled, interrupt-driven, or 
DMA basis, in any combination. 

The IUSC can be programmed using 16-bit data on the 
AD15-0 lines or 8-bit data on AD15-8 and AD7-0. The 
distinction between 8- and 16-bit operations is made as 
part of the address map rather than via a control input. The 
D//C pin of the IUSC is driven from A7 during slave cycles, 
and the S//D pin is driven from A8. The overall address 
range of the IUSC is 384 bytes from (PBA)+512 through 
(PBA)+895. 

The first write to this address range, after a Reset, implicitly 
writes the lUSC's Bus Configuration Register (BCR). To 
match up with the rest of the board's hardware, this first 
write is a 16-bit write, storing the recommended hex value 
00F7 at any word address in the range (PBA)+768 through 
(PBA)+830. Details of this transaction are as follows: 

■ The High on the lUSC's S//D input, which is connected 
to A8, selects the WAIT protocol on the /WAIT//RDY 
pin, which is how the 80186 works. 



■ It may not be required for this initial write, but it is good 
programming form for A6 to be zero since this is a word 
write. This and the previous point determine the 
recommended address range. 

■ The MSB of the data (D15) is because a separate 
non-multiplexed address is not wired to pins AD1 3:8 of 
the IUSC. 

■ Bits 14-8 are more or less required to be all by the 
lUSC's internal logic. 

■ D7-6 are 1 1 to allow the DMA controllers to do either 
1 6-bit transfers, or alternating byte transfers on AD7- 
for even-addressed bytes and on AD15-8 for odd- 
addressed bytes. This is compatible with 801 86 byte 
ordering. 

■ D5-4 of the data are 1 1 to select double-pulsed mode 
for the lUSC's /INTACK input. Again, this is how the 
80186 works. 

■ D3 of the data is to select open-drain mode on the 
lUSC's /BUSREQ pin. The board's control logic also 
drives this signal low when the ISCC asserts its Bus 
Request output. 

■ D2 of the data is 1 to tell the IUSC that the data bus is 
16 bits wide. 
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IUSC (Continued) 

■ D1 of the data is 1 to select open-drain mode on the 
lUSC's /INT pin which is OR-tied with the interrupt 
request from the (E)SCC. 

■ DO of the data is 1 to select Shift Right Address mode, 
so that the IUSC subsequently takes register 
addressing from the AD6-0 lines rather than from 
AD7-1. 



■ The fact that the lUSC's internal logic sees activity on 
its /AS pin, which is inverted from the 80186' ALE 
signal, automatically conditions it for a multiplexed 
Address/Data bus. 

Given that the BCR is written as above, the IUSC slave- 
mode address map is as follows: 



Starting Addr Ending Addr Registers Accessed 



(PBA)+512 


(PBA)+575 


16-bit 


access 


to 


IUSC 


Transmit DMA registers 


(PBA)+576 


(PBA)+639 


8-bit 


access 


to 


IUSC 


Transmit DMA registers 


(PBA)+640 


(PBA)+703 


16-bit 


access 


to 


IUSC 


Receive DMA registers 


(PBA)+704 


(PBA)+767 


8-bit 


access 


to 


IUSC 


Receive DMA registers 


(PBA)+768 


(PBA)+831 


16-bit 


access 


to 


IUSC 


Serial Controller registers 


(PBA)+832 


(PBA)+895 


8-bit 


access 


to 


IUSC 


Serial Controller registers 



While the ESCC and ISCC can drive their Baud Rate 
Generators from their PCLK inputs, the IUSC cannot do 
this from its CLK input. The 801 86 clock output SYSCLK is 
brought to pins 7 of J9, J 10, and J12 at which point it can 
be jumpered to pin 9 or 8 so that it is routed to the /TxC or 
/RxC pin of the device. 



Since the IUSC contains its own DMA channels, its /RxREQ 
and /TxREQ pins have no dedicated function. They can be 
used for Request to Send and Data Terminal Ready; the 
two signals are lightly pulled up to allow for the fact that 
they are not driven after Reset. 



SERIAL INTERFACING 

The serial I/O pins of the four serial controllers are connected 
to the six connector blocks labelled J5 through J 10. In 
addition, the port pins of the IUSC are connected to the J 1 1 
connector block, and the port pins of an MUSC or the B 
channel of a USC are connected to J12. These connector 
blocks can be interconnected for communication between 
on-board serial controllers, or they can be connected to 
the user's custom communications hardware on another 
board. As a third option, they can be connected to three 
on-board serial interfaces via the connector blocks labelled 
J13 through J15. 

Two of the on-board serial interfaces use EIA-RS-232 
signal levels and pin arrangement. 25-pin D connectors 
J1 A or J2A are configured as DTE, while J1 B and J2B are 



configured as DCE. These serial interfaces are used by 
connecting one of J5- J 1 to J 1 3 or J 1 4, respectively. J 1 B 
is typically used for connection to the user's PC or terminal. 

The third on-board serial interface uses EIA-422 signal 
levels on connector J3A.J3B, or J4, and is used by 
connecting one of J5-J 1 to J 1 5. The 25-pin D connector 
J3A uses the DTE pin arrangement put forth in the EIA-530 
standard. J3B is a DCE version of EIA-530, while the 8-pin 
circular DIN connector, J4, is compatible with the Apple 
Macintosh Plus and later Macintoshes, and thus with 
AppleTalk/LocalTalk equipment. 
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The serial interface connectors are summarized in the 
following tables: 



Table 7. Controller Port Connectors 



To use the following serial controller channel Connect to this (these) 1 0-pin 
with off-board or on-board serial hardware: connector block(s): 

(E)SCC Channel A J5 

(E)SCC Channel B J6 

ISCC Channel A J7 

ISCC Channel B J8 

IUSC J9 (J 11 for Port pins) 

(M)USC J10(J12 for MUSC Port pins 

or USC channel B) 



Table 8. On-Board Line Driver/Receiver Connectors 



To use a serial controller with the 


Connect the connector(s) 


following on-chip serial interface: 


from the previous table to: 


J 1 A or J 1 B El A-RS-232 Console 


J13 


J2A or J2B EIA-RS-232 


J14 


RS-422 differential: J3A or J3B EIA-530 or J4 Circular-8 (DIN) 


J15 



The pin-out of the J5-J10 connectors is fairly consistent, 
but of necessity not identical because of differences 
among the various serial controllers: 



Table 9. Pin Assignments of Standard Controller Connectors 



Pin# 


J5: (E)SCC 
A pin 


J6:(E)SCC 
B pin 


J7,8: ISCC 
pin 


J9: IUSC 
pin 


J10: MUSC 
or USC A pin 


J12:USC 
B pin 


1 


TxD 


TxD 


TxD 


TxD 


TxD 


TxD 


2 


RxD 


RxD 


RxD 


RxD 


RxD 


RxD 


3 


/RTS 


/RTS 


/RTS 


(NC) 


/RxACK 


/RxACK 


4 


/CTS 


/CTS 


/CTS 


/CTS 


/CTS 


/CTS 


5 


/DTR 


/DTR or (NC) [1] 


/DTR 


(NC) 


/TxACK 


/TxACK 


6 


/DCD 


/DCD 


/DCD 


/DCD 


/DCD 


/DCD 


7 


/SYNC 


/SYNC 


/SYNC 


(SYSCLK) 


(SYSCLK) 


(SYSCLK) 


8 


/RTxC 


/RTxC 


/RTxC 


/RxC 


/RxC 


/RxC 


9 


/TRxC 


/TRxC 


fTRxC 


/TxC 


ATxC 


/TxC 


10 


GND 


GND 


GND 


GND 


GND 


GND 


11 


NA 


NA 


NA 


/TxREQ 


/TxREQ 


/TxREQ 


12 


1 2 


NA 


NA 


NA /Rx 


EQ /Rx 


EQ /Rx 



7-69 



SERIAL INTERFACING (Continued) 

The ground pins are included as signal references with off- 
board hardware. 

When interconnecting between two connectors among 
J5-J 1 0, DO NOT jumper corresponding pins straight across, 
as this connects outputs to outputs and inputs to inputs. 

Rather, connect at least each pin 1 to the other pin 2, and 
enough opposing inputs and outputs as needed to make 
the communication protocol meaningful. 



The pin-out of the 12-pin J 13- 15 connectors is similar to 
that of J5-10, but more extensive. To allow for the "DCE" 
connectors that were added in revision "B" of the board, 
J13 and J14 are 16-pin headers and J15 is a 14-pin one: 



Table 10. Pin Assignments of Line Driver/Receiver Connectors 



Pin # 


J13-14 


J13-14 


J15 J15 


Direction/where used 




DTE signal 


DCE signal 


I DTE signal DCE signal 




1 


TxD 


RxD 


TxD RxD 


Output to J1 -4 


2 


RxD 


TxD 


RxD TxD 


Input from J 1-4 


3 


/RTS 


/CTS 


/RTS /CTS 


Output to J 1-3 


4 


/CTS 


/RTS 


/CTS /RTS 


Input from J1-4 [3] 


5 


/DTR 


/DSR 


/DTR /DSR 


Output to J 1-4 


6 


/DSR 


/DTR 


/DSR /DTR 


Input from J1-4 


7 




/DCD 


/DCD 


Output to J 1B, J2B, J3B 


8 


/DCD 




/DDC 


Input from J1 A, J2A, J3A, J4 


9 
10 


GND 


GND 


GND GND 




11 




/RxC 


/RxC 


Output to J1B.J2B.J3B 


12 


/RxC 




/RxC 


Input from J1 A, J2A. J3A 


13 


/TxCO 


flxCI 


/TxCO /TxCI 


Output to J 1-3 


14 


/TxCI 


/TxCO 


/TxCI /TxCO 


Input from J1-3 [3] 


15 




/Rl 




Output to J 1B, J2B 


16 


/Rl 






Input from J1A, J2A 



Note: 

[3] Various conventions have been used to combine synchronous clock inputs and modem control inputs on Apple Macintosh connectors similar to 
J4, as described in a later section. 



Comparison of the two preceding charts leads to several 
conclusions: 

■ Pins 1 -5 can always be jumpered straight across from 
a J5-1 connector block to a J1 3-1 5 connector block. 

■ In a synchronous environment, the Transmit clock can 
be either driven or received and the Receive clock can 
be received from the DTE connector or sent on the 
DCE connector. 



The 10-pin J11 and J12 jumper blocks provide for 
connections to the Port pins of the IUSC and (M)USC, 
respectively. As with J5-10, these connections may be to 
the customer's off-board custom circuits and/or to certain 
pins in the J13-15 blocks. The following pin assignment is 
determined so that if a 2-channel USC is plugged into the 
(M)USC socket, J 1 2 has the same pin-out for the (JSC's B 
channel as do J5-10 for other channels. 
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Table 11. Pin Assignments of Controller Port Connectors 



Pin # 


.111- IIJ^O Sinnal 




1 


PORT1 (Clock 1 In) 


PORT1 


2 


PORT4 (XmitTSA Gate Out) 


PORT4 (Xmit TSA Gate Out) 


3 


(NC) 


(NC) 


4 


PORTO (Clock In) 


PORTO 


5 


(NC) 


(NC) 


6 


PORT3 (Rev TSA Gate Out) 


PORT3 (Rev TSA Gate Out) 


7 


(NC) 


(SYSCLK) 


8 


PORT5 (Rev Sync Out) 


PORT5 (Rev Sync Out) 


9 


PORT2 


PORT2 


10 


GND 


GND 


11 


PORT6 (Rev Sync In) 


PORT6 (Rev Sync In) 


12 


PORT7 (Xmit Complete Out) 


PORT7 (Xmit Complete Out) 



Finally, an unpopulated 4-pin oscillator socket is included 
on the board with its output connected to a single 
jumper/wire-wrap pin. This socket can be populated with 
a user-supplied oscillator and connected to various clock 
pin(s) among J5-J15. 

Sensing which Serial Controller Channel 
is connected to the Console 

In order to use the software provided with this evaluation 
board, one of the serial controller channels must be 
connected to a Personal Computer (or a dumb terminal) 
via the J1 and J13 connectors. Some versions of this 
software may restrict the choice to (E)SCC Channel A or 
the (M)USC, depending on the user's applications needs, 
but there is nothing in the hardware that limits the choice 
of which serial channel is used for the Console. However, 
on the J1-4 (J 13-1 5) side there are two things that are 
special about the J1/J13 section as compared to the 
others. One is the provision for a Non-Maskable Interrupt 
in response to a received Start bit, as described earlier in 
the section on (E)SCC addressing. 

Software can use the other special feature of the J1/J13 
section, after a Reset, to sense which serial channel is 
connected to the Console port. A Reset signal (from 
power-on or the Reset button, but not from the Reset-the- 
ISCC, etc., address decode as described earlier) puts the 
"NMI" EPLD in a special mode wherein the first Start bit on 
the Console's Transmit Data lead causes an NMI. This 
feature can be used in a start-up procedure like the 
following, to tell which serial controller channel is used for 
the Console: 



For each serial controller channel that the software can 
use for the Console: 

1. Initialize the channel. 

2. Send a NUL character to the channel. 

3. Wait a short time to see if an NMI occurs. If so, the 
current channel is the Console. If not, go on to the next 
serial channel and try again. 

If none of the allowed serial channels produces an NMI, the 
user has not properly jumpered any J5-1 connector block 
to the J1 3 block. 

Basic software should use the serial controller channel for 
the Console in a very basic, polled way. Because of this 
and because of similarities between the (E)SCC and the 
ISCC, and between the (M)USC and the IUSC, note that 
software allows the Console to be connected to either the 
(E)SCC channel A or to the (M)USC; in fact, it includes most 
of the code necessary to use any of the six serial controller 
channels for the Console. 

Notes on J4/Macintosh/AppleTalk/LocalTalk 

The J4 connector is similar to that offered on various 
Macintosh systems. The ESCC and ISCC are particularly 
well adapted for use with this port, and development of 
USC family capability for AppleTalk/LocalTalk is of interest. 
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SERIAL INTERFACING (Continued) 



The J3 and J4 connectors cannot be used simultaneously. 
The J1 6 jumper block controls whether the RS-422 driver 
for Transmit Data is turned "on" and "off" under control of 
the associated Request to Send signal, as on the Mac, or 
is "on" full time, which is more suitable for the use of J3. To 
put the TxD driver under control of RTS, jumper J 16-1 to 
J 1 6-2 and leave J1 6-3 open. For full-time drive on TxD (and 
also the J3 RTS pins), jumper J 16-2 to J 16-3 and leave 
J16-1 open. 

The J17 jumper block controls whether the reception of 
Data Carrier Detect and Clear to Send is differential (on J3) 
or unbalanced, as on J4. To use differential signalling from 
J3, remove all jumpers from J 17. 

On the initial Macintosh and subsequent ones as well, 
Apple did the unbalanced signalling backward from 
standard RS-423 and RS-232 polarity for the CTS lead 
(also called HSK and HSKI). If you're developing code for 
Macintosh hardware, you can preserve Mac compatibility 
by jumpering J17-3 to J17-5 and J17-4 to J17-6. This 
grounds the CTS- lead and connects the CTS+ lead to 
J4-2. It also (assuming a standard source at the other end) 
inverts CTS to the opposite sense from that expected by 
the serial controller for functions such as auto-enabling. To 
make the CTS input of the serial controller have its normal 
(low-true) sense, jumper J17-3 to J17-4, and J 17-5 to 
J 1 7-6 - this grounds the CTS+ lead and connects the CTS- 
leadtoJ4-2. 

The DTR (HSKO) output is provided in Apple systems from 
Mac Plus onward and has standard RS-423 (and RS-232) 
polarity. 



The DCD input on J4-7 is provided in Apple systems from 
the Mac II and SE onward, and also has standard polarity 
on Apple hardware. Jumper J17-1 to J 17-2 to ground the 
+ input of the receiver; the - lead is connected to J4-7. 

With jumpers installed to make DCD and CTS unbalanced, 
J4 can also be used for an additional RS-232 serial link. 
Connect a "Mac to Hayes modem" cable to J4, and 
optionally a null modem interconnect module to the other 
end. The cable internally grounds the RxD+ and TxD+ 
leads so that RxD- and TxD- act like RS-232 signals. 

Macintosh systems also include provisions for synchronous 
clock inputs. It is not known whether these features are 
used by any applications, or attached hardware. On all 
known Macs, the SCC's TRxC pin is driven from the same 
signal as CTS; to be compatible with this feature, connect 
J 15-4 to pins 4 and 9 of the selected connector among 
J5-J10. 

On the Mac SE, Mac II, and later models, a multiplexing 
scheme is provided on SCC channel A's RTxC pin to drive 
from either the same signal as DCD, or from an on-board 
3.672 MHz clock. (Channel B always had the 3.672 MHz 
clock.) The former capability can be provided by connecting 
J 1 5-6 to pins 6 and 8 of the selected connector among J5- 
J10. The latter capability can be only approximated using 
the 80186 clock with different baud rate divisors, or by 
using another oscillator. (The board includes an 
unpopulated 4-pin oscillator socket that might be useful in 
this regard.) 
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JUMPER SUMMARY 



Table 1 2 includes only those connector blocks intended to actual connectors meant for use with cables, jumper wires, 
be populated by 2-pin option jumpers. J 1 -J 15 and J26 are or wire-wrapped connections. 



Table 12. Two-Pin Option Jumpers 



Jumpers 


Installed 


Open 


IQ 7 thru Q 

jtw inru -y 


7 tn Q- QfYIQR CVCPI Y ic II ICP /DvP 

1 10 o. oUloD oYoUUS IS IUoU /nXU 

7 to 9: 80186 SYSCLK is IUSC /TxC 


o. oomeming eise on /nxo, or inu 
9: Something else on /TxC, or NC 


J10-7 thru -9 


7 to 8: 80186 SYSCLK is MUSC (USC A) /RxC 
7 to 9: 80186 SYSCLK is MUSC (USC A) /TxC 


8: Something else on /RxC, or NC 
9: Something else on /TxC, or NC 


J1 2-7 thru -9 


7 to 8: 80186 SYSCLK is USC B /RxC 
7 to 9: 80186 SYSCLK is USC B /TxC 


8: Something else on /RxC, or NC 
9: Something else on /TxC, or NC 


J16-1 thru -3 


1 to 2: J3, J4TxD driven when RTS 

2 to 3: J3, J4 TxD, RTS driven full-time 


Must install one or the other 


J17-1 to -2 


Unbalanced DCD- on J3 or J4 


Differential DCD+, DCD- on J3 


117 thru R 


o 10 o ana *t 10 o. u i o+ on oh-c 
3 to 4 and 5 to 6: CTS- on J3 or J4 


nifforontial PTQj. PTQ nn IQ 

uiiiciciuidi o i o+, o i o- on Jo 


HQ 1 thru Q 

j i o- 1 inru -o 


1 tn 0' 07R/1 071 OQ 070RR EPQPiMc 
1 10 L dlOH, lI\lo % cfcOO trnUIVIS 

2to3:27512EPROMs 


Musi insiaii one or me oiner 


J19-1 thru -6 


1 to 2 and 4 to 5: 128Kx8 SRAMs 

2 to 3 and 5 to 6: 32Kx8 SRAMs 


Must install one way or the other 


J20-1 thru -3 


1 to 2: U2 contains 80C30 or 80230 

2 to 3: U2 contains 85C30 or 85230 


Must install one way or the other 


J21-1 thru -6 


1 to 2 and 4 to 5: U2 contains 80C30 or 80230 

2 to 3 and 5 to 6: U2 contains 85C30 or 85230 


Must install one way or the other 


J22-1 thru -4 


1 to 2: MUSC (USCA)RxREQ on DMAO 

1 to 3: MUSC (USC A) RxREQ on DMA1 

2 to 4: MUSC (USC A) TxREQ on DMA 

3 to 4: MUSC (USC A) TxREQ on DMA 1 


1:MUSC (USC A) Rx no DMA 
4: MUSC (USC A) Tx no DMA 


J23-1 thru -3 


1 to 2: (E)SCCBRxRQon DMAO 

2 to 3: (E)SCCB Wait function 


(E)SCCB neither Rx DMA 
nor Wait 


J24-1 thru -4 


1 to 2: clipped SCC B TxREQ on DMA 1 
1to3: direct ESCCB TxREQ on DMA1 
3 to 4: /DTR output from ESCCB 


(E)SCCB neither Tx DMA 
nor /DTR 


J25-1 thru - 5 and J25X 


1 to 2 and 3 to 4: (E)SCC last on IACK chain, 
MUSC second to last 

J25X to 2 and 3 to 4- (FVSCC last USC 2nd to last 

2 to 3 and 4 to 5: (E)SCC first on IACK chain 


Must be one of these three ways 


J28-1 thru -6 


1 to 2: 80186 SYSCLK is (E)SCC PCLK 
3 to 4: 80186 SYSCLK is ISCC PCLK 
5 to 6: 80186 SYSCLK is IUSC CLK 


Connect some other clock to 2, 4, or 6 


J29-1 thru -4 


1 to 2: USC B RxREQ on DMAO 

1 to 3: USC B RxREQ on DMA 1 

2 to 4: USCBTxREQon DMAO 

3 to 4: USCBTxREQon DMA1 


1:USCBRxnoDMA 
4: USC B Tx no DMA 
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EPLD LOGIC 



AO 

/Bx x 



/SWR 
HLDA 



ALE 



/S2 



HI AD1 
HI ADO 



__INPUT 

□XD vcc 

. INPUT 



NOT NAND2 



, INPUT 

H=> VCC 



P- —INPUT 
l g0 > QND 



i> n-[ >J 



IOR8 | C| ' 



±Z> /SWRE 




H3 /bin 



^5 > /SALE 



-tIIZ> SALE 



NOT 

-t>- 



o 



/RAMCSO 



/RAMCS 1 



-T9 > /RAMCS2 



Figure 1. Control EPLD for 186 Bd 
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/ALTRES ro-oo> x ^c 
RESET rooo^ X ^^ T 



/SRD 



NORLTCH 



ALE/GND IWo 



SYSCLK looo 



/BOUT 



/DMAwSCC ro~o~r> 1 "c" T 



/EBTxRQ rgoo V ygg T 



D- 



■D»- 



B N O R 2 

i=2> 

<l (Z <^ NOH4 



33- 



/ I NT AO looo > 




- fo"oo> /RESET 




HD /DS//RD 




o"o~T> / AS//WR 



goo> /SWR 



Bioin _____ , _ . , _ 

vc * <ooor> /isccwr 



oo~) R//W 



NOR2 



> 



~_-T> /SCCTxRQ 



Y_r 



CLRN 



Figure 2. SCC EPLD for 186 Bd 
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DMA EPLD LOGIC 



/S2 
/S 1 

/so 

ALE 



. . I N P U T 

1 * 9 >— 



1 n p u t 1 — g A 

o=> vcc — — g > 

. i n p u t I Q y 

I=3-nTcc 1 



BANDS LATCH 



/ I SBRQ □ 



-INPUT 



"l> 

^ T.RI 



4^ 



/MURQO 1 9 > - 

/EBRXRQ lia >- 



3I> 



B N O P 2 



/MURQ1 I i o >- 

/EBTXRQ Us >- 



3I> 



-£>o OUTPUT 



a * > /SCCINTA 



^^<rO /IUBRQ 



^ ^ OUTPUT 

kND2 

C N OUTPUT 

d J 

^ N D 2 

C ^ OUTPUT 



7 > HOLD 



3 > DREQO 



ZZZ> DREQ1 



l o o o y 



INPUT 



/ A < o o o Y 



Figure 3. DMA EPLD for 186 Bd 
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NANDLTCH 



NC 
NO 



RN 
SN 



CONSRxD rooo V ^" T P>>- 



loo o 
loop 
looo 



A5 
A6 

/ESCS 
/SRD 

RESET 



CONSTxD rFpp 



Li ? vcc 



vc c 

INPUT 




1 



> 



CLRN 

o 



V I— D Q 



CLR N 



CA19/S6 rooTV - 



t>°- 



ooo> NMI 



- fp~P~P> /DMAWSCC 



NOTE: S6 High in Data time 
indicates cycle f /8OIB6 DMA 



/MUCSO 
/MUCS 1 



Hl> /MUCS 



Figure 4. NMI EPLD for 186 Board 
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Application Note 



SCC In Binary 

Synchronous 

Communications 



October 1982 



Zilog's Z8030 Z-SCC Serial Communications Control- 
ler is one of a family of components that are 
Z-BUS*' compatible with the Z800CT CPU. Combined 
with a Z8000 CPU (or other existing 8- or 16-bit 
CPUs with nonmultiplexed buses when using the 
Z8530 SCC), the Z-SCC forms an integrated data 
communications controller that is more cost effec- 
tive and more compact than systems incorporating 
UARTs, baud rate generators, and phase-locked 
loops as separate entities. 



• Block/DMA Mode. Using the Wait/Request (W/REQ) 
signal, the Z-SCC introduces extra wait cycles 
to synchronize data transfer between a 
CPU or DMA controller and the Z-SCC. 

The example given here uses the block mode of data 
transfer in its transmit and receive routines. 



SYNCHRONOUS MODES 



The approach examined here implements a communica- 
tions controller in a Binary Synchronous mode of 
operation, with a Z8002 CPU acting as controller 
for the Z-SCC. 

One channel of the Z-SCC is used to communicate 
with the remote station in Half DupLex mode at 
9600 bits/second. To test this application, two 
ZBOOO Development Modules are used. Both are 
loaded with the same software routines for ini- 
tialization and for transmitting and receiving 
messages. The main program of one module requests 
the transmit routine to send a message of the 
length indicated in the 'COUNT' parameter. The 
other system receives the incoming data stream, 
storing the message in its resident memory. 

MT\ TRANSFER MOOES 

The Z-SCC system interface supports the following 
data transfer modes: 

a Polled Mode. The CPU periodically polls the 
Z-SCC status registers to determine the avail- 
ability of a received character, if a character 
is needed for transmission, and if any errors 
have been detected. 

i Interrupt Mode. The Z-SCC interrupts the CPU 
when certain previously defined conditions are 
met. 



Three variations of character-oriented synchronous 
communications are supported by the Z-SCC: Mono- 
sync, Bisync, and External Sync (Figure 1). In 
Monosync mode, a single sync character is trans- 
mitted, which is then compared to an identical 
sync character in the receiver. When the receiver 
recognizes this sync character, synchronization is 
complete; the receiver then transfers subsequent 
characters into the receiver FIFO in the Z-SCC. 

_ y> . 

I SYNC DATA DATA CRC1 CRC2 

L. // 1 

a. MONOSYNC MODE 



SYNC SYNC DATA DATA CRC1 CRC2 | 
1 

b. BISYNC MODE 

EXTERNAL 
SYNC SIGNAL 

t— 1 

| OAT A DATA CRC1 CRC2 
' / / — 1 

c. EXTERNAL SYNC MODE 

Figure 1. Synchronous Modes of Communication 

Bisync mode uses a 16-bit or 12-bit sync character 
in the same way to obtain synchronization. Exter- 
nal Sync mode uses an external signal to mark the 
beginning of the data field; i.e., an external 
input pin (SYNC) indicates the start of the infor- 
mation field. 
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In all synchronous modes, two Cyclic Redundancy 
Check (CRC) bytes can be concatenated to the mes- 
sage to detect data transmission errors. The CRC 
bytes inserted in the transmitted message are com- 
pared to the CRC bytes computed to the receiver. 
Any differences found are held in the receive 
error FIFO. 



SYSTEM INTERFACE 

The Z8002 Development Module consists of a Z8002 
CPU, 16K words of dynamic RAM, 2K words of EPROM 



Two Z8000 Development Modules containing Z-SCCs 
are connected as shown in Figure 3 and Figure 4. 
The Transmit Data pin of one is connected to the 
Receive Data pin of the other and vice versa. The 
Z8002 is used as a host CPU for loading the 
modules' memories with software routines. 

The Z8000 CPU can address either of the two bytes 
contained in 16-bit words. The CPU uses an even 
address (16 bits) to access the most -significant 
byte of a word and an odd address for the least - 
significant byte of a word. 



Z8000 
CPU 



; buffer dt) 



A K ADDRESS/ A 

( ) DATA ( 

\| y BUFFER \| 



SEGMENT 
ADDRESS 
BUFFER 



\ STATUS \ 

J DECODER J 



WIRE WRAP AREA 

""<*v 



SERIAL 
OUTPUT 
BUFFERS 



Z80A PIO's 

(2) 



Z80A CTC 



— \ SE 

V (2) 



RS-232C 
SERIAL 
CHANNELS 



SI02 



ADDRESS/DATA BUS 



EPROM 

EPROM CONTROL BUS )l MEMORY 

(8K WORDS MAX) 



RAM CONTROL BUS 



\ DYNAMIC A. 

) RAM MEMORY ( 
y (32K WORDS MAX) \j" 



EXTERNAL 
CLOCK ( 
IN/OUT 



Figure 2. Block Diagram of Z8000 DM 



monitor, a Z80A SIO providing dual serial ports, a 
Z80A CTC peripheral device providing four counter/ 
timer channels, two Z80A PIO devices providing 32 
programmable I/O lines, and wire wrap area for 
prototyping. The block diagram is depicted in 
Figure 2. Each of the peripherals in the develop- 
ment module is connected in a prioritized daisy-c- 
hain configuration. The Z-SCC is included in this 
configuration by tying its IEI line to the IEO 
line of another device, thus making it one step 
lower in interrupt priority compared to the other 
device. 





TxD 


RxD 




Z8002 
Z-SCC 


TRxC 
RTxC 
RxD 


RTxC 
TRxC 
TxD 


Z8002 
Z-SCC 


LOCAL 






REMOTE 


Figure 3. 


Block Diagraa of Two Z8000 



Development Modules 
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IAD 1S - 
lADu - 
IAD 13 « 
IA0 12 - 



IAD,, - 
IAD 10 - 
IAO9 - 
IADs " 



GBAGAB 



ADis 
AOu 
AD13 
AD 12 



AD11 
AD 10 
AD» 
AD, 



DS 
MREQ 

ST 3 
ST 2 
ST, 
ST 



IAD 6 


10 


IAD5 

IAD4 * 


11 



13^1 



AD7 
ADe 
AD 5 
AD 4 



IAD3 - 
IAD 2 - 
IAD1 - 
IADq - 



Q BAGAB 
l777 



AD3 
ADa 
AD, 
ADo 



WAIT 1 
STOP 1 



LS 
244 



WAIT 
STOP 



4^ 



NMi 

RESTf 
CLOCK 



do 




15 


TxDA 
RxDA 
TRxCA 
WAIT 


13 


14 


10 


12 


RTxCA 



IADs » ^ O- 



Figure 4. Z8002 with SCC 



When the Z8002 CPU uses the lower half of the 
Address/Data bus (ADg-ADy the least significant 
byte)* for byte read and write transactions during 
I/O operations, these transactions are performed 
between the CPU and I/O ports located at odd I/O 
addresses. Since the Z-SCC is attached to the CPU 
on the lower half of the A/D bus, its registers 
must appear to the CPU at odd I/O addresses. To 
achieve this, the Z-SCC can be programmed to 
select its internal registers using lines 
AD-j-ADj. This is done either automatically with 
the Force Hardware Reset command in WR9 or by 
sending a Select Shift Left Mode command to WROB 
in channel B of the Z-SCC. For this application, 
the Z-SCC registers are located at I/O port 
address 'FExx 1 . The Chip Select signal (CSO) is 
derived by decoding I/O address 'FE' hex from 
lines ADg-AD«j5 of the controller. The Read/Write 
registers are automatically selected by the Z-SCC 
when internally decoding lines AD1-AD5 in Shift 
Left mode. To select the Read/Write registers 
automatically, the Z-SCC decodes lines AD^-AD^ in 
Shift Left mode. The register map for the Z-SCC 
is depicted in Table 1. 

INITIALIZATION 

The Z-SCC can be initialized for use in different 
modes by setting various bits in its Write regis- 
ters. First, a hardware reset must be performed 
by setting bits 7 and 6 of WR9 to one; the rest of 
the bits are disabled by writing a logic zero. 

Bisync mode is established by selecting a 16-bit 
sync character, Sync Mode Enable, and a X1 clock 
in WR4. A data rate of 9600 baud, NRZ encoding, 
and a data character length of eight bits are 
among the other options that are selected in this 
example (Table 2). 

Note that WR9 is accessed twice, first to perform 
a hardware reset and again at the end of the ini- 
tialization sequence to enable the interrupts. 
The programming sequence depicted in Table 2 
establishes the necessary parameters for the 
receiver and the transmitter so that, when 
enabled, they are ready to perform communication 
tasks. To avoid internal race and false interrupt 
conditions, it is important to initialize the reg- 
isters in the sequence depicted in this applica- 
tion note. 



Table 1. Register Hap 



Address 



(hex) 


Write Register 


Read Register 


FE01 


WROB 


RROB 


FE03 


WR1B 


RR1B 


FE05 


WR2 


RR2B 


FE07 


WR3B 


RR3B 


FE09 


WR4B 




FEOB 


WR5B 




FEOD 


WR6B 




FEOF 


WR7B 




FE11 


B DATA 


B DATA 


FE1? 


WR9 




FE15 


WR10B 


RR10B 


FE17 


WR11B 




FE19 


WR12B 


RR12B 


FE1B 


WR13B 


RR13B 


FE1D 


WR14B 




FE1F 


WR15B 


RR15B 


FE21 


WROA 


RROA 


FE23 


WR1A 


RR1A 


FE25 


WR2 


RR2A 


FE27 


WR3A 


RR3A 


FE29 


WR4A 




FE2B 


WR5A 




FE2D 


WR6A 




FE2F 


WR7A 




FE31 


A DATA 


A DATA 


FE33 


WR9 




FE35 


WR10A 


RR10A 


FE37 


WR11A 




FE39 


WR12A 


RR12A 


FE3B 


WR13A 


RR13A 


FE3D 


WR14A 




FE3F 


WR15A 


RR15A 



The Z8002 CPU must be operated in System mode in 
order to execute privileged I/O instructions, so 
the Flag Control Word (FCW) should be loaded with 
System/Normal (S/N), and the Vectored Interrupt 
Enable (VIE) bits set. The Program Status Area 
Pointer (PSAP) is loaded with address 84400 using 
the Load Control instruction (LDCTL). If the Z8000 
Development Module is intended to be used, the 
PSAP need not be loaded by the programmer as the 
development modules monitor loads it automatically 
after the NMI button is pressed. 
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Table 2. Programing Sequence 
for Initialization 





Value 




Register 


(hex) 


Effect 


WR9 


LU 


Hardware reset 


WR4 


10 


x1 clock, 16-bit sync, sync mode 






enable 


WR10 





NRZ, CRC preset to zero 


WR6 


AB 


Any sync character "AB" 


WR7 


CD 


Any sync character "CD" 


WR2 


20 


Interrupt vector "20" 


WR11 


16 


Tx clock from BRG output, TRxC 






pin = BRG out 


WR12 


CE 


Lower byte of time constant = 






"CE" for 9600 baud 


WR13 





Upper byte = 


WR14 


03 


BRG source bit = 1 for PCLK as 






input, BRG enable 


WR15 


00 


External interrupt disable 


WR5 


64 


Tx 8 bits/character, CRC-16 


WR3 


C1 


Rx 8 bits/character, Rx enable 






(Automatic Hunt mode) 


WR1 


08 


Rxlnt on 1st char & sp. cond., 






ext. int. disable) 


WR9 


09 


MIE, VIS, Status Low 


Since VIS and Status Low are selected in WR9, the 


vectors 


listed 


in Table 3 will be returned during 


the Interrupt 


Acknowledge cycle. Of the four 


interrupts listed, only two, Ch A Receive Charac- 


ter Available and Ch A Special Receive Condition, 


are used in the example given here. 




Table 3. Interrupt Vectors 




PS 




Vector 


Address* 


(hex) 


(hex) 


Interrupt 


28 


446E 


Ch A Transmit Buffer Empty 


2A 


4472 


Ch A External Status Change 


2C 


4476 


Ch A Receive Char. Available 


2E 


447A 


Ch A Special Receive Condition 



♦ "PS Address" refers to the location in the Pro- 
gram Status Area where the service routine 
address is stored for that particular interrupt, 
assuming that PSAP has been set to 4400 hex. 



TRANSMIT OPERATION 

To transmit a block of data, the main program 
calls up the transmit data routine. With this 
routine, each message block to be transmitted is 
stored in memory, beginning with location 'TOUT*. 
The number of characters contained in each block 
is determined by the value assigned to the •COUNT 1 
parameter in the main module. 

To prepare for transmission, the routine enables 
the transmitter and selects the Wait On Transmit 
function; it then enables the wait function. The 
Wait On Transmit function indicates to the CPU 
whether or not the Z-SCC is ready to accept data 
from the CPU. If the CPU attempts to send data to 
the Z-SCC when the transmit buffer is full, the 
Z-SCC asserts its Wait line and keeps it Low until 
the buffer is empty. In response, the CPU extends 
its 1/0 cycles until the Wait line goes inactive, 
indicating that the Z-SCC is ready to receive 
data. 

The CRC generator is reset and the Transmit CRC 
bit is enabled before the first character is 
sent, thus including all the characters sent to 
the Z-SCC in the CRC calculation, until the Trans- 
mit CRC bit is disabled. CRC generation can be 
disabled for a particular character by resetting 
the TxCRC bit within the transmit routine. In 
this application, however, the Transmit CRC bit is 
not disabled, so that all characters sent to the 
Z-SCC are included in the CRC calculation. 

The Z-SCC s transmit underrun/EOM latch must be 
reset sometime after the first character is trans- 
mitted by writing a Reset Tx Underrun/EOM command 
to WR0. When this latch is reset, the Z-SCC auto- 
matically appends the CRC characters to the end of 
the message in the case of an underrun condition. 

Finally, a five-character delay is introduced at 
the end of the transmission, which allows the 
Z-SCC sufficient time to transmit the last data 
byte, two CRC characters, and two sync characters 
before disabling the transmitter. 



RECEIVE OPERATION 

Once the Z-SCC is initialized, it can be pre- 
pared to receive data. First, the receiver is 
enabled, placing the Z-SCC in Hunt mode and thus 
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setting the Sync/Hunt bit in status register RRO 
to 1. In Hunt mode, the receiver is idle except 
that it searches the incoming data stream for a 
sync character match. When a match is discovered 
between the incoming data stream and the sync 
characters stored in WR6 and WR7, the receiver 
exits the Hunt mode, resetting the Sync/Hunt bit 
in status register RRO and establishing the 
Receive Interrupt On First Character mode. Upon 
detection of the receive interrupt, the CPU gener- 
ates an Interrupt Acknowledge cycle. The Z-SCC 
sends to the CPU vector SS2C, which points to the 
location in the Program Status Area from which the 
receive interrupt service routine is accessed. 

The receive data routine is called from within 
the receive interrupt service routine. While 
expecting a block of data, the Wait On Receive 
function is enabled. Receive data buffer RR8 is 
read, and the characters are stored in memory 
locations starting at RBUF. The Start of Text 
(5o02) character is discarded. After the End of 
Transmission character (J504) is received, the two 
CRC bytes are read. The result of the CRC check 
becomes valid two characters later, at which time, 
RR1 is read and the CRC error bit is checked. If 
the bit is zero, the message received can be 
assumed correct; if the bit is 1, an error in the 
transmission is indicated. 



Before leaving the interrupt service routine, 
Reset Highest IUS (Interrupt Under Service), 
Enable Interrupt on Next Recieve Character, and 
Enter Hunt Mode commands are issued to the Z-SCC. 

If a receive overrun error is made, a special con- 
dition interrupt occurs. The Z-SCC presents the 
vector 5o2E to the CPU, and the service routine 
located at address 5S447A is executed. The Special 
Receive Condition register RR1 is read to deter- 
mine which error occurred. Appropriate action to 
correct the error should be taken by the user at 
this point. Error Reset and Reset Highest IUS 
commands are given to the Z-SCC before returning 
to the main program so that the other lower prior- 
ity interrupts can occur. 

SOFTWARE 

Software routines are presented in the following 
pages. These routines can be modified to include 
various versions of Bisync protocol, such as 
Transparent and Nontransparent modes. Encoding 
methods other than NRZ (e.g., NRZI, FMO, FM1) can 
also be used by modifying WR10. 
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j ****************** INITIALIZATION ROUTINE FOR Z-SCC *********************** I 



0034 GLOBAL INIT PROCEDURE 

ENTRY 



0034 


2100 


LD 


R0,#15 


1NO.OF PORTS TO WRITE TO I 


0036 


000F 








0038 


7602 


LDA 


R2 , SCCTAB 


1 ADDRESS OF DATA FOR PORTS I 


003A 


004E' 








003C 


2101 


ALOOP: LD 


Rl , IWR0A 




003E 


FE21 








0040 


0029 


ADDB 


RL1,§R2 




0042 


A920 


INC 


R2 




0044 


3A22 


OUTIB 


@R1,§R2,R0 


1 POINT TO WR0A/HR1A ETC THRO LOOP1 


0046 


0018 








0048 


8D04 


TEST 


R0 


1END OF LOOP? 1 


004A 


EEF8 


JR 


NZ, ALOOP 


1 NO, KEEP LOOPING 1 


004C 


9E08 


RET 






004E 


12 


SCCTAB i BVAL 


2*9 




004F 


CO 


BVAL 


%C0 


1WR9 "HARDWARE RESET 1 


0050 


08 


BVAL 


2*4 




0051 


10 


BVAL 


%10 




0052 


14 


BVAL 


2*10 




0053 


00 


BVAL 


o 


IWRIO'CRC PRESET ZERO,NRZ,16 BIT SYNC I 


0054 


OC 


BVAL 


2*6 




0055 


AB 


BVAL 


%AB 


IWRfisANY SYNP PHAR &ARI 


0056 


OE 


BVAL 


2*7 




0057 


CD 


BVAL 


%CD 


IWR7«ANY SYNC CHARR ftCDl 
l ri *\ / nil x 0xiiw vnniui ivu§ 


0058 


04 


BVAL 


2*2 




0059 


20 


BVAL 


%20 


1WR2«INT VECTOR %201 


005A 


16 


BVAL 


2*H 




005B 


16 


BVAL 


%16 


IWRll-TxCLOCK k TRxC OUT«BRG OUT1 


005C 


18 


BVAL 


2*12 




005D 


CE 


BVAL 


%CE 


1WR12- LOWER TC-%CE1 


005E 


1A 


BVAL 


2*13 




005F 


00 


BVAL 





1WR13- UPPER TC-01 


0060 


1C 


BVAL 


2*14 




0061 


03 


BVAL 


%03 


1WR14"BRG ON, ITS SRC-PCLKl 


0062 


IE 


BVAL 


2*15 




0063 


00 


BVAL 


%00 


1WR15-NO EXT INT EN. 1 


0064 


OA 


BVAL 


2*5 




0065 


64 


BVAL 


%64 


1WR5- TX 8 BITS/CHAR, CRC-16I 


0066 


06 


BVAL 


2*3 




0067 


CI 


BVAL 


%C1 


IWR3-RX 8 BITS/CHAR, REC ENABLE I 


0068 


02 


BVAL 


2*1 


0069 


08 


BVAL 


%08 


IWRl-RxINT ON 1ST OR SP CONDI 
1 EXT INT DI SABLE 1 


006A 


12 


BVAL 


2*9 




006B 


09 


BVAL 


%09 


1WR9- MIE, VIS, STATUS LOW1 



006C END INIT 



I****************** RECEIVE ROUTINE ************************************{ 

1 RECEIVE A BLOCK OF MESSAGE 1 

1 THE LAST CHARACTER SHOULD BE EOT(%04) 1 



006C 




GLOBAL RECEIVE 
ENTRY 


PROCEDURE 




006C 


C828 


LDB 


RL0,#%28 


IWAIT ON RECV. I 


006E 


3A86 


OUTB 


WR0A+2,RL0 




0070 


FE23 








0072 


6008 


LDB 


RL0,%A8 




0074 


00A8 








0076 


3A86 


OUTB 


WR0A+2,RL0 


1 ENABLE WAIT 1ST CHAR, SP.COND. 


0078 


FE23 








007A 


2101 


LD 


Rl , #RR0A+16 




007C 


FE31 








007E 


3C18 


INB 


RL0 , @R1 


1READ STX CHARACTER 1 


0080 


C8C9 


LDB 


RL0,#%C9 




0082 


3A86 


OUTB 


WR0A+6,RL0 


IRx CRC ENABLE 1 


0084 


FE27 








0086 


2103 


LD 


R3 , IRBUF 




0088 


5400 








008A 


3C18 


READ: INB 


RL0,@R1 


1READ MESSAGE 1 


008C 


2E38 


LDB 


§R3,RL0 


1 STORE CHARACTER IN RBUF1 


008E 


AB30 


DEC 


R3,*l 




0090 


0A08 


CPB 


RL0,*%04 


US IT END OF TRANSMISSION ?! 


0092 


0404 








0094 


EEFA 


JR 


NZ , READ 




0096 


3C18 


INB 


RL0,@R1 


1READ PAD1! 


0098 


3C18 


INB 


RL0,@R1 


I READ PAD21 


009A 


3A84 


INB 


RLO,RR0A+2 


1READ CRC STATUS 1 


009C 


FE23 












1 PROCESS CRC ERROR IF ANY, AND 


GIVE ERROR RESET COMMAND IN WR0A 


009E 


C800 


LDB 


RL0,*0 




00 AO 


3A86 


OUTB 


WR0A+6,RL0 


1 DISABLE RECEIVER I 


00A2 


FE27 








00A4 


9E08 


RET 






00A6 




END RECEIVE 
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I**************** TRANSMIT ROUTINE ************************************ | 

1 SEND A BLOCK OF DATA CHARACTERS 1 

1 THE BLOCK STARTS AT LOCATION TBUP I 



00A6 




GLOBAL TRANSMIT PROCEDURE 








ENTRY 






00A6 


2102 


LD 


R2, ITBUF 


1PTR TO START OF BUFFER 1 


00A8 


0028' 








OOAA 


C86C 


LDB 


RLOf #%6C 




00 AC 


3A86 


OUTB 


WROA+10* RLO 


1 ENABLE TRANSMITTER! 


00AE 


FE2B 








00B0 


C800 


LDB 


RL0,#%00 


I WAIT ON TRANSMIT 1 


00B2 


3A86 


OUTB 


WR0A+2,RL0 




00B4 


FE23 








00B6 


C888 


LDB 


RL0 r t%88 




00B8 


3A86 


OUTB 


WR0A+2,RL0 


IWAIT ENABLE r INT ON 1ST 6 SP CONDI 


OOBA 


FE23 








OOBC 


C880 


LDB 


RL0 r #%80 




OOBE 


3A86 


OUTB 


WROAf RLO 


1 RESET TxCRC GENERATOR 1 


00C0 


FE21 








00C2 


2101 


LD 


R1,#WR0A+16 


1WR8A SELECTED 1 


00C4 


FE31 








00C6 


C86D 


LDB 


RL0» #%6D 




00C8 


3A86 


OUTB 


WR0A+10 r RL0 


!Tx CRC ENABLE 1 


OOCA 


FE2B 








OOCC 


2100 


LD 


RO, #1 




OOCE 


0001 








O0D0 


3A22 


OTIRB 


8R1 i @R2 , RO 


1SEND START OF TEXT! 


00D2 


0010 








00D4 


C8C0 


LDB 


RLO f #%C0 




00D6 


3A86 


OUTB 


HROAfRLO 


1 RESET TxUND/EOM LATCH 1 


00D8 


FE21 








OODA 


2100 


LD 


RO f tCOUNT-1 




OODC 


OOOB 








OODE 


3A22 


OTIRB 


@R1,@R2,R0 


1SEND MESSAGE 1 


OOEO 


0010 








00E2 


C804 


LDB 


RL0 r *%04 




00E4 


3 El 8 


OUTB 


@Rl r RL0 


1SEND END OF TRANSMISSION CHARACTER 1 


00E6 


2100 


LD 


R0,#1670 


1 CREATE DELAY BEFORE DISABLING 1 


00E8 


0686 








OOEA 


F081 


DBLt DJNZ 


R0 r DEL 




OOEC 


C800 


LDB 


RL0,#0 




OOEE 


3A86 


OUTB 


WR0A+10,RL0 


1 DISABLE TRANSMITTER! 


00F0 


FE2B 








00F2 


9E08 


RET 






00F4 




END TRANSMIT 








1 




INT. SERVICE 


ROUTINE *************************! 


OOF4 




GLOBAL REC PROCEDURE 








ENTRY 






00F4 


93F0 


PUSH 


@R15,R0 




00F6 


3A84 


INB 


RLOf RROA 


1READ STATUS FROM RR0A1 


00F8 


FE21 








OOFA 


A684 


BITB 


RL0,#4 


1TEST IF SYNC HUNT RESET! 


OOFC 


EE02 


JR 


NZ , RESET 


1YES CALL RECEIVE ROUTINE! 


OOFE 


5F00 


CALL 


RECEIVE 




0100 


006C 








0102 


C808 


RESET j LDB 


RL0,#%08 




0104 


3A86 


OUTB 


WR0A+2,RL0 


IWAIT DISABLE! 


0106 


FE23 








0108 


C8D1 


LDB 


RL0,#%D1 




010A 


3A86 


OUTB 


WR0A+6,RL0 


1 ENTER HUNT MODE! 


010C 


FE27 








010E 


C820 


LDB 


RL0,#%20 




0110 


3A86 


OUTB 


WR0A,RL0 


! ENABLE INT ON NEXT CHAR! 


0112 


FE21 








0114 


C838 


LDB 


RL0,#%38 




0116 


3A86 


OUTB 


HROAfRLO 


I RESET HIGHEST IUS1 


0118 


FE21 






011A 


97F0 


POP 


R0,§R15 




one 


7B00 


IRET 






011E 




END REC 
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1 



SPECIAL CONDITION INTERRUPT SERVICE ROUTINE 



I 



011E GLOBAL SPCONO PROCEDURE 

ENTRY 



011E 


93P0 


PUSH 


@R15,R0 


0120 


3A84 


INB 


RL0,RR0A+2 


0122 


FE23 










1 PROCESS ERRORS 1 


0124 


C830 


LDB 


RL0,#%30 


0126 


3A86 


OUTB 


WR0A,RL0 


0128 


PE21 






012A 


C808 


LDB 


RLO,#%08 


012C 


3A86 


OUTB 


WR0A+2,RL0 


012E 


FE23 






0130 


C8D1 


LDB 


RL0,*%D1 


0132 


3A86 


OUTB 


WR0A+6,RL0 


0134 


PE27 






0136 


C838 


LDB 


RL0,M38 


0138 


3A86 


OUTB 


WR0A/RL0 


013A 


FE21 






013C 


97P0 


POP 


R0,§R15 


013E 


7B00 


IRET 





0140 END SPCOND 



END BISYNC 

errors 
Assembly complete 



1READ ERRORS 1 
1 ERROR RESET 1 

1WAIT DISABLE, RxINT ON 1ST OR SP COND. 1 
1HUNT MODE, RE C. ENABLE 1 
I RESET HIGHEST IUS1 
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<£2iLCE 
SCC (Serial Communication Controller): 

SDLC MODE OF OPERATION 



If n demanding the transactions which occur within a Serial Communication Controller 
U operating in the SDLC mode simplifies working in this complex area. 



INTRODUCTION 

Zilog's SCC (Serial Communication Controller) is a popular 
USART (Universal Synchronous/Asynchronous Receiver/ 
Transmitter) device, used for a wide range of applications. 
For instance, Macintosh systems use the SCC as a standard 
communication controller device. There are several different 
types of devices in the SCC family. The family consists of 
the Z8530 NMOS SCC, the Z85C30 CMOS SCC, the 
Z85230 ESCC (Enhanced SCC), Z85233 EMSCC (Mono 
Enhanced SCC), and Superintegration devices such as 
the Z181 ZIO™ andZ182 ZIP™. 

Since the SCC may be used in many different ways, it may 
not be easy to understand all the transactions involved 
between the CPU and the SCC. In particular, the SDLC 
mode of operation is highly complicated, and many 
transactions are involved to make it work properly. This 
application note describes the sequence of events which 
occurs in the SDLC mode of operation. 

The following sequences of events are covered: 

■ SDLC Transmission 

■ SDLC receive 

- With Receive Interrupts on all received characters 
or Special Conditions 

- With Receive Interrupts on First Character or 
Special Condition 

- With Receive Interrupts on Special Conditions 
only 

■ Receiving Back-to-back Frame under DMA control 

■ SDLC Loop mode 



Each section explains the transmit/receive process for 
packets with the following characteristics: 



■ 


Initial state is mark idle 


■ 


Address field has 81 H 


■ 


Control field has 42H 


■ 


Two bytes of l-field, 42H and OFFH 


■ 


After the closing flag, mark idling 


Note: 



This application note describes the SCC, but not the 
ESCC. The ESCC, since it incorporates enhancements like 
deeper FIFOs and SDLC mode supporting logic, handles 
the packets much more simply than the SCC. Refer to the 
section on CMOS SCC and ESCC of this appnote for more 
general information on the ESCC. 
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SDLC TRANSMIT 



Figure 1 shows the time chart for the transmitting SDLC 
packet under interrupt control. When transmit is engaged, 
data is shifted out of the transmitter on the falling edge of 
the transmit clock. Transitions on the diagram are shown 



coincident with TxCLK fall — in actual practice, there are 
some associated delay times (which are specified in the 
datasheet). 
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Notes on Figure 1 : 

1. The SCC has two possible idle states, Mark idle 
(contiguous logic 1 ) or Flag idle (repeating flag pattern 
7EH). In this figure, the SCC has to be switched to flag 
idle in order to send the opening flag of the frame. Care 
must be taken not to put the first data byte (in this case, 
address 81 H) into the Transmit Buffer too soon after 
the switchover from Mark idle to Flag idle has been 
made; otherwise, the data may be loaded into the 
Transmit Shift Register before the flag is loaded. To 
ensure that this cannot happen, a delay must be 
executed before the first data byte is put into the 
buffer. The delay time is dependent on the data rate 
and a safe minimum duration is 8 bit-times. 

2. Transmit Buffer Empty Interrupt for 81 H. At this point 
the data has just been transferred to the Transmit Shift 
Register and data 42H is written to the Transmit Buffer. 

3. The time between the first data byte being transferred 
to the Shift Register and the first bit appearing at the 
TxD pin is always six bit-times. 

4. Transmit Buffer Empty Interrupt for data 42H. Data 
OFFH is written to the Transmit Buffer at this point. 



5. Transmit Buffer Empty Interrupt for data OFFH. Data 
42H is written to the Transmit Buffer at this point. 

6. The time between interrupts depends on the data 
character length and the number of zero insertions in 
the character. For 8 bits/character it can vary between 
8 and 10 bit-times. The particular instance shown 
corresponds to the single zero insertion when the byte 
OFFH is transmitted. 

7. Transmit Buffer Empty Interrupt for data 42H. Since 
this is the last byte to be transmitted , the Reset Transmit 
Interrupt Pending command is issued instead of writing 
another byte to the Transmit Buffer. 

8. Transmitter Underrun/EOM Interrupt. This occurs when 
both the Transmit Shift Register and the Transmit 
Buffer are empty. It is an External/Status interrupt. The 
data sent when this occurs is summarized in the table 
below: 



Abort/Flagon Tx Underrun/EOM Latch Data 

Underrun bit State when Underrun occurs Sent 

Reset CRC and Flag 

1 Reset Abort and Flag 

Set Flags 

1 Set Flags 



9. The transmitted CRC is 16 bits long provided that there frame is to be transmitted, the first character of the next 
are no zero insertions. In theory it could be as long as frame can be loaded. The two frames will then be 
19 bits. separated by a single flag (Back-to-back frame). 

10. The last interrupt generated occurs after the CRC is 11. If the SCC is set up for mark on idle and a new 
shifted out of the transmitter and a flag is loaded to be character is not loaded when the last interrupt occurs, 
sent. It is a Transmit Buffer Empty Interrupt. If another only a single flag is sent. 
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SDLC RECEIVE 



There are several different ways to receive a SDLC packet 
on the SCC; by polling, by Interrupts and by DMA. The 
SCC has the following four Receive Interrupt Modes: 

■ Disabled. This should be used in the Polling mode. 

■ Interrupts on all received characters or Special 
Conditions. This mode should be used for normal 
interrupt-driven operation. 

■ Interrupts on First Character or Special Condition. This 
mode is intended for received data transfer by the 
DMA, and enables the DMA when the interrupt is 
received by the First Character of the packet. 

■ Interrupt on Special Condition only. This mode allows 
the DMA to free-run and keep transferring data to the 
buffer. This is an ideal mode for the CMOS SCC as well 
as the ESCC with Status FIFO enabled, because the 
Status FIFO can give byte count and error status 
without interrupting data transfer operations. 



Each of the four cases is covered in this application note 
except Receive Interrupt disabled. For polling, the basic 
operation is identical to that used for "interrupt on all 
characters or Special Condition" mode. Instead of waiting 
for an interrupt, polling Reads Registers to determine if 
service is needed or not. 

On the SCC, data is sampled by the receiver on the rising 
edge of the receive clock. Set-up and hold times for RxD 
with respect to RxC are specified in the product 
specifications. 

In general, receiver status changes are triggered by RxC. 
In the following Figures, they are shown as being coincident 
with this edge — in actual practice, there are some 
associated delay times (which are specified in the data 
sheet). 



RECEIVE INTERRUPTS ON ALL RECEIVE CHARACTERS OR SPECIAL CONDITIONS 



SCC is placed in this mode by programming Bit D4-3 of 
WR1 to 10. Once programmed in this mode, the SCC 
generates interrupts whenever character(s) are in the 
receive buffer or when Special Conditions occur. This 
mode is the most common operational mode. 

Notes on Figure 2: 

1 . The receiver is usually in hunt mode when waiting for 
a frame. When the opening flag is received, an External/ 
Status Interrupt is generated, indicating the change 
from hunt mode to sync mode. 

2. The /SYNC output follows the state of the sync register 
comparison output. The comparison is done on a bit 
by bit basis, so the /SYNC pin is only active for one bit- 
time. /SYNC goes active one bit-time after the last bit 
of the sync character is sampled at the RxD pin. 

3. A Receive Character Available Interrupt is generated 
1 1 bit-times 8 bits for the shifter and a 3-bit delay) after 
the last bit of the character is sampled at the RxD pin. 
The status bits corresponding to that character must 
be read before the data character is read from the 
Receive Buffer. This interrupt is for data 81 H. 

4. Receive Character Available Interrupt for data 42H. 

5. Receive Character Available Interrupt for data OFFH. 



6. Receive Character Available Interrupt for data 42H. 

7. Receive Character Available Interrupt for the first CRC 
byte. The SCC treats the CRC as data, since the SCC 
does not yet distinguish a difference between CRC 
and data! 

8. The closing flag is recognized two bit-times before the 
second CRC byte is completely assembled in the 
Receive Shift Register. As soon as it is recognized, a 
Special Condition interrupt is generated. The EOF bit 
is set at this point and the CRC error bit can be 
checked. The six least significant bits of the second 
CRC byte are present at the top of the first CRC byte. 
The status information must be read before the second 
CRC byte is read from the buffer. The CRC bytes 
should be discarded. The CRC checker is automatically 
reset for the next frame. 

9. External/Status interrupt for the Sync/Hunt change. 
This occurs when the SCC recognizes an Abort 
(Marking line) and forces the receiver into hunt mode. 
The SCC can be programmed so that the Abort itself 
generates an interrupt if required. If flag idle was set, 
this interrupt will not occur. 
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RxCLK 




Rx Data 



Opening Flag Data 81 H ^ Data42H ^ Data OFFH ^ Data42H ^ 



CRC0E013H 



Closing Rag ^| 



r-i Note 9 



/INT 



Note 4 



Note 5 



/SYNC 



Figure 2. Typical SDLC Receive Sequence with Receive Interrupts on all Received Characters or Special Condition. 



RECEIVE INTERRUPTS ON FIRST CHARACTER OR SPECIAL CONDITIONS 



The sequence of events in this mode is similar to that in 
"Receive Interrupts on all received characters and Special 
Conditions", except that it generates Receive Character 
Interrupt on the first received character only, and 
subsequent data is read by the DMA. 

The SCC is placed in this mode by programming Bit D4-3 
of WR1 to 01. Once programmed in this mode, the SCC 
generates interrupts when it receives the First Character of 
the packet or a Special Condition occurs. This mode is for 



operation with the DMA. On the interrupt for the first 
received character, DMA is enabled. On Special Conditions 
(either End-of-Message, overrun, or Parity error, — parity 
on the SDLC is not normal, however), the service routine 
stops the DMA and starts over again. 
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Notes on Figure 3: 



1 . The receiver is usually in hunt mode when waiting for 
a frame. When the opening flag is received, an External/ 
Status Interrupt is generated, indicating the change 
from hunt mode to sync mode. 

2. The /SYNC output follows the state of the sync register 
comparison output. The comparison is done on a bit 
by bit basis, so the /SYNC pin is only active for one bit- 
time. /SYNC goes active one bit-time after the last bit 
of the sync character is sampled at the RxD pin. 

3. A Receive Character Available Interrupt is generated 
1 1 bit-times after the last bit of the character is sampled 
at the RxD pin. In this mode, enable the DMA on this 
interrupt. This interrupt is for data 81 H. 

4. If SCC's DMA request function has been enabled, 
/REQ becomes active here. 

5. DMA request for data 42H. 

6. DMA request for data OFFH. 

7. DMA request for data 42H. 

8. DMA request for the first CRC byte. The SCC treats the 
CRC as data, since the SCC does not yet distinguish 
a difference between CRC and data! 

9. DMA request for the second CRC byte. The closing 
flag is recognized two bit-times before the second 
CRC byte is completely assembled in the Receive 
Shift Register. As soon as it is transferred to the 
Receive Buffer, it generates a DMA request. 



1 0. This interrupt is EOF (End of Frame), a Special Condition 
interrupt. This will not occur until the DMA has read the 
2nd CRC byte from the Receive Buffer. When it occurs, 
the Receive Buffer is locked and no more DMA requests 
can be generated until the Receive Buffer is unlocked 
by issuing the Error Reset command. Before issuing 
this command, all of the status bits required (e.g., the 
CRC error status) must be read, and the last two bytes 
read by the DMA discarded. The enable interrupt on 
next Receive Character command must be sent to the 
SCC so that the next character (i.e., the First Character 
of the next frame) will produce an interrupt. If this is not 
done, the character will generate a DMA request, not 
an interrupt. 

Should a Special Condition occur within the data 
stream (i.e., for a condition other than EOF) the /INT pin 
will not go active until the character with the Special 
Condition has been read by the DMA. 

1 1 . DMA request for 2nd CRC bytes. This occurs when the 
EOF interrupt service routine has not disabled the 
DMA function of the SCC, and did not read the data 
after unlocking the buffer by issuing an Error Reset 
command. 

12. External/Status Interrupt for the Sync/Hunt change. 
This occurs when the SCC recognizes an Abort 
(Marking line) and forces the receiver into hunt mode. 
The SCC can be programmed so that the Abort itself 
generates an interrupt if required. If flag idle was set, 
this interrupt would not occur. 
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RECEIVE INTERRUPTS ON SPECIAL CONDITIONS ONLY 



The sequence of event in this mode is similar to that for 
"Receive Interrupts on first received character or Special 
Condition," except it will not generate Receive Character 
Available interrupt at all. This mode is designed for 
operations where the DMA is pre-programmed, or the 
application does not have enough time to set up DMA 
transfer on First Character interrupt. 

The SCC is placed in this mode by programming Bit D4- 
3 of WR1 to 1 1 . Once programmed in this mode, the SCC 
generates interrupts when Special Conditions occur. On 
Special Condition (either End-Of-Message or overrun/ 
Parity error, if enabled ), corrective action can be taken for 
that packet. 

The SDLC Frame Status Buffer (not available on the NMOS 
version) is very useful in this mode. First of all, set DMA to 



transfer several packets. The SDLC Frame Status Buffer 
holds information which tells you how many bytes were in 
the received packet and reports whether or not error 
conditions (overrun/CRC error/parity error) have occurred. 

The sequence of events in this mode is identical to the 
"Receive Interrupts on First Character or Special Condition" 
mode (Figure 3); Note 3, however, does not apply, and 
Note 4 should read as follows for this case: 

Note 4 in Receive Interrupts on Special Condition only 
mode: 

DMA request for data 81 H. The DMA function of the SCC 
should be enabled by this time frame. 



RECEIVING BACK TO BACK FRAME IN RECEIVE 
INTERRUPTS ON SPECIAL CONDITION ONLY MODE 



"Back to Back" frame means there are two frames separated 
with only one flag — the closing flag of the previous packet 
also acts as the opening flag of the following packet. 
Receiving such packets is identical to receiving a single 
packet, except that the sequence of events happens in a 
short time around the shared flag. 

Assuming SCC is running under Receive Interrupts on 
Special Condition only mode (under DMA Control), a 
typical sequence of events is shown in Figure 4. It is 
identical to that used for "Receive Interrupts on Special 
Condition Only" mode, with the addition of another following 
packet. 

Notes on Figure 4: 

1 . DMA request data before OFFH. 

2. DMA request for data OFFH. 

3. DMA request for data 42H. 

4. DMA request for the first CRC byte. The SCC treats the 
CRC as data, since the SCC does not yet distinguish 
a difference between CRC and data! 

5. DMA request for the second CRC byte. The closing 
flag is recognized two bit-times before the second 
CRC byte is completely assembled in the Receive 
Shift Register. As soon as it is transferred to the 
Receive Buffer, it generates a DMA request. 



6. This interrupt is EOF (End of Frame), a Special Condition 
Interrupt. This will not occur until the DMA has read the 
2nd CRC byte from the Receive Buffer. When it occurs 
the Receive Buffer is locked and no more DMA requests 
can be generated until the Receive Buffer is unlocked 
by issuing the Error Reset command. Before this 
command is issued, all of the status bits required (e.g., 
the CRC error status) must be read, and the last two 
bytes read by the DMA discarded. The Enable Interrupt 
on Next Receive Character command must be sent to 
the SCC so that the next character (i.e., the First 
Character of the next frame) will produce an interrupt. 
If this is not done, the character will generate a DMA 
request, not an interrupt. 

On unlocking the Receive Buffer after the EOF interrupt, 
no initialization is required with respect to the receiver. 
All characters have been removed by the DMA and the 
receiver is ready for the next frame. While the Buffer is 
locked the SCC can receive 2 7/8 characters (8 bits/ 
character) before there is a danger of the receiver 
overrunning. The only way that this can be specified is 
by referencing it to the falling edge of the request for 
the last CRC byte. This time is a worst case minimum 
of 33 bit-times (possi bly more if there are any characters 
with inserted zeros). As soon as the Buffer is unlocked 
an additional 8 (minimum) bit-times become available 
because the top byte of the Buffer is freed up. 
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Rx Data 



Data OFFH I Data 42H 



CRC 0E013H 
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Data 07H 
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Note 6 



/W//REQ (In /REQ mode) 



Note 1 



Note 2 



Mote 3 



Note 4 



Note 5 Note 7 



Note 9 ^ 
frote8 



/SYNC 



Figure 4. Receiving "Back to Back" frame with Receive Interrupts on Special Condition Only mode (DMA Controlled) 



RECEIVING BACK TO BACK FRAME IN RECEIVE 
INTERRUPTS ON SPECIAL CONDITION ONLY MODE 

(Continued) 

7. DMA request for second CRC byte. This occurs when 8. DMA request for data 01 H. 
the EOF interrupt service routine has not disabled the 

DMA function of the SCC, and fails to read the data 9. DMA request for data 03H. 

after unlocking the FIFO by issuing Error Reset 

command. 



SDLC LOOP MODE 



The SDLC Loop mode is one of the protocols used in the 
ring configuration network topology. The typical network 
configuration is shown in Figure 5. As shown, there is one 
Master (or primary) station and several slave (or secondary) 
stations. This figure does not have a clock connection, but 



each station's transmit clock must be synchronized to the 
master SCC. This can be done by feeding the clock using 
a separate clock line, or by using Phase Locked Loop 
(PLL) to recover the clock. 



Master SCC 

Tx Rx 



Rx Tx 

Slave SCC #1 



Rx Tx 

Slave SCC #2 



Rx Tx 

Slave SCC #n 



Figure 5. SDLC Loop Mode Configuration 



This mode is similar to the normal SDLC mode, other than 
that secondary stations are not allowed to freely send out 
packets. When a secondary station wants to send a 
packet, it needs to wait for a special pattern to be received. 
The pattern is called EOP (End Of Poll), and consists of a 
followed by seven 1 s on the transmission line (as data, it 
is 11111110). This pattern resembles the SDLC Flag 
pattern (7EH; 0111110), except the last bit has been 
changed to a 1 thus turning this pattern into a flag. 



Upon network initialization, secondary station TxD and 
RxD connections use gate propagation delay. On the first 
EOP, a secondary station inserts one bit -time delay between 
RxD and TxD, and relays RxD input to TxD. When it has a 
message to send out, it waits for an EOP. When it detects 
EOP in this phase, it changes the last bit of the EOP to zero, 
making it a Flag, then begins to send its own message. 
From this point on, normal SDLC transmission modes 
apply. Packets conclude with Mark idle, identifying it as an 
EOP pattern. The secondary station then reverts back to 
one bit delay mode. 
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TxD (Master), RxD (Slave) 



81h| 42h| Offh 



h ,|. 42h .|. CRC ,| 



TxD (Slave) 



-I 



Note 2 



I Note 7 | Oaahl 55h I 55h I Oaahl CRC I IfopI 

r — T t I t t 1 




/INT (Slave) 



Ext/Stat 

(Break/Abort Set) Note 6 Note 8 



...... KJ \/ 



/INT (Master) 



Ext/Stat Ext/Stat Ext/Stat ^ v ^ * 

(Break/Abort set) (Break/Abort set) (Break/Abort clr) RCA RCA RCA RCA RCA \ TxBE TxBE Txllnderrun 

Sp. Cond 

■JxBE 



TxBE TxBE TxBe" F* ca ^ ca R° a R° a R° a \ ^ CA * CA ^ CA ^ CA RCASpXond 



Sp. Cond 



RCA: Receive Character Available Interrupt 
TxBE: Tx Buffer Empty Interrupt 



Figure 6. SDLC Loop Mode 
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SDLC LOOP MODE (Continued) 



Notes on Figure 6: 

1 . The master SCC sends EOP by switching from flag on 
idle to mark on idle 

2. At initialization, all Slave stations were set up for SDLC 
loop mode At this point, the Slave station connects its 
RxD pin to TxD pin with gate propagation delay, and 
starts to monitor Rx data for the EOP sequence. 

3. On receiving the EOP, the slave generates an External/ 
Status Interrupt with Break/Abort bit set. A one bit time 
delay is inserted between RxD and TxD. (The GAOP.Go 
active on Poll, bit should be reset at this point to avoid 
unexpected loop entry by the Slave transmitter.) The 
Slave's on-loop bit is set and the receiver is in hunt 
mode. 

4. Note that there is a one bit time delay between received 
data and transmitted data. 

5. When the Slave wants to transmit it must first receive 
an EOP and have GAOP set. 



6. On receiving an EOP, the Slave interrupts with Break/ 
Abort clear. The EOP is converted to a flag, the loop 
sending bit is set, and the transmitter will send flags 
until data is written into the Transmit Buffer. 

7. Note that the flags overlap. 

8. When the slave has sent all of its data the GAOP flag 
should be cleared so that the CRC is sent on underrun . 

9. When the closing flag has been sent the Slave reverts 
to a one bit delay, which produces another EOP. 

10. The master must keep its output marking until its 
receiver has received all frames sent by secondaries. 



CMOS SCC AND ESCC 

The discussion above applies to the NMOS SCC and the 
CMOS SCC without the SDLC Frame Status FIFO feature. 
The CMOS version and the ESCC have a SDLC Frame 
Status FIFO for easier handling of the SDLC mode of 
operation. The SDLC Status FIFO is designed for DMA 
controlled SDLC receive for high speed SDLC data 
transmission, or for systems whose CPU interrupt 
processing is not fast. 

This FIFO is able to store up to 10 packets' worth of byte 
count (14-bit count) and status information (Overrun/Parity/ 
CRC error status). To use this feature, simply enable this 
FIFO and let DMA transfer data to memory. While DMA is 
transferring received data to the memory, the CPU will 
check the FIFO and locate the data in memory, as well as 
the status information of the received packet. 

Other ESCC enhancements make it easier to handle the 
SDLC mode of operation. These include: 

■ Deeper FIFO (4 Bytes Transmit, and 8 Bytes receive) 

■ Automatic Opening Flag transmission 



■ Fast /DTR//REQ mode 

■ Complete CRC reception 

■ Receive FIFO Antilock feature 

■ Programmable DMA and interrupt request level 

■ Improved data setup time specification 

For more details on these functions, please refer to the 
SCC/ESCC Technical manual and related documents. 

CONCLUSION 

This application note describes the basic operation of the 
SCC in SDLC operational modes. With minor variations, 
most of these operations also apply to the CMOS SCC with 
Status FIFO enabled and the ESCC. 



■ Automatic EOM reset 

■ Automatic /RTS deactivation 
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Application note 



Using SCC with Z8000 
in SDLC Protocol 



This application note describes the use of the 
Z8030 Serial Communications Controller (Z-SCC) 
with the Z800D^ CPU to implement a communica- 
tions controller in a Synchronous Data Link 
Control (SDLC) mode of operation. In this 
application, the Z8002 CPU acts as a controller 
for the Z-SCC. This application note also applies 
to the non-multiplexed Z853G. 

One channel of the Z-SCC communicates with the 
remote station in Half Duplex mode at 9600 
bits/second. To test this application, two Z8O00 
Development ModuLes are used. Both are loaded with 
the same software routines for initialization and 
for transmitting and receiving messages. The main 
program of one module requests the transmit 
routine to send a message of the length indicated 
by the 'COUNT' parameter. The other system 
receives the incoming data stream, storing the 
message in its resident memory . 

DATA TRANSFER MODES 

The Z-SCC system interface supports the following 
data transfer nodes: 

• Polled Mode- The CPU periodically polls the 
Z-SCC status registers to determine if a 
received character is available, if a character 
is needed for transmission, and if any errors 
have been detected. 

• Interrupt Mode. The Z-SCC interrupts the CPU 
when certain previously defined conditions are 
met. 

• Block/DMA Hide. Using the Wait/Request (W/REQ) 



signal, the Z-SCC introduces extra wait cycles 
in order to synchronize the data transfer 
between a controller or DMA and the Z-SCC. 

The example given here uses the block mode of data 
transfer in its transmit and receive routines. 

SDLC PROTOCOL 

Data communications today require a communications 
protocol that can transfer data quickly and 
reliably. One such protocol, Synchronous Data 
Link Control (SDLC), is the link control used by 
the IBM Systems Network Architecture (SNA) 
communications package. SDLC is a subset of the 
International Standards Organization (ISO) link 
control called High-Level Data Link Control 
(HDLC), which is used for international data 
communications. 

SDLC is a bit-oriented protocol (BOP). It 
differs from byte-control protocols (BCPs), such 
as Bisync, in that it uses only a few bit 
patterns for control functions instead of several 
special character sequences. The attributes of 
the SDLC protocol are position dependent rather 
than character dependent, so the data link control 
is determined by the position of the byte as well 
as by the bit pattern. 

A character in SDLC is sent as an octet, a group 
of eight bits. Several octets combine to form a 
message frame, in which each octet belongs to a 
particular field. Each message contains: opening 
flag, address, control, information, Frame Check 
Sequence (FCS), and closing flag (figure 1). 
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Figure 1. Fields of the SDLC Transmission Frame 



Both flag fields, contain a unique binary pattern, 
01111110, which indicates the beginning or the end 
of the message frame. This pattern simplifies the 
hardware interface in receiving devices so that 
multiple devices connected to a common link do not 
conflict with one another. The receiving devices 
respond only after a valid flag character has been 
detected. Once communication is established with 
a particular device, the other devices ignore the 
message until the next flag character is detected. 

The address field contains one or more octets, 
which are used to select a particular station on 
the data link. An address of eight 1s is a global 
address code that selects all the devices on the 
data link. When a primary station sends a frame, 
the address field is used to select one of several 
secondary stations. When a secondary station 
sends a message to the primary station, the 
address field contains the secondary station 
address, i.e., the source of the message. 

The control field follows the address field and 
contains information about the type of frame 
being sent. The control field consists of one 
octet that is always present. 

The information field contains any actual 
transferred data. This field may be empty or it 
may contain an unlimited number of octets. 
However, because of the limitations of the 



error-checking algorithm used in the frame-check 
sequence, however, the maximum recommended block 
size is approximately 4096 octets. 

The frame check sequence field follows the 
information or control field. The FCS is a 16-bit 
Cyclic Redundancy Check (CRC) of the bits in the 
address, control, and information fields. The FCS 
is based on the CRC-CCITT code, which uses the 
polynomial (x 16 + x 12 + x 5 + 1). The Z8030 Z-SCC 
contains the circuitry necessary to generate and 
check the FCS field. 

Zero insertion and deletion is a feature of SDLC 
that allows any data pattern to be sent. Zero 
insertion occurs when five consecutive 1s in the 
data pattern are transmitted. After the fifth 1, a 
is inserted before the next bit is sent. The 
extra does not affect the data in any way and is 
deleted by the receiver, thus restoring the 
original data pattern. 

Zero insertion and deletion insures that the data 
stream will not contain a flag character or abort 
sequence. Six 1s preceded and followed by 0s 
indicate a flag sequence character. Seven to 
fourteen 1s signify an abort; 15 or more 1s 
indicate an idle (inactive) line. Under these 
three conditions, zero insertion and deletion are 
inhibited. Figure 2 illustrates the various line 
conditions. 



A. ZERO INSERTION 

FLAG ADDRESS CONTROL FLAG 

I Q111111Q T 10101Q11 I Q11111Q11 | j I Q111111Q | data Stream 
t 

ZERO INSERTION 

ADDRESS = 10101011 
CONTROL = 01111111 

B. ABORT CONDITION 

xxxx111111101111110 

ABORT FLAG 

C. IDLE CONDITION 

XXXX111111111111111 

Figure 2. Bit Patterns for Various Line Conditions 
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The SDLC protocol differs from other synchronous 
protocols with respect to frame timing. In Bisync 
mode, for example, a host computer might 
temporarily interrupt transmission by sending sync 
characters instead of data. This suspended 
condition continues as long as the receiver does 
not time out. With SDLC, however, it is invalid to 
send flags in the middle of a frame to idle the 
line. Such action causes an error condition and 
disrupts orderly operation. Thus, the trans- 
mitting device must send a complete frame without 
interruption. If a message cannot be transmitted 
completely, the primary station sends an abort 
sequence and restarts the message transmission at 
a later time. 



SYSTEM INTERFACE 

The Z8002 Development Module consists of a Z8002 
CPU, 16k words of dynamic RAM, 2k words of EPROM 
monitor, a Z80A SIO providing dual serial ports, a 
Z801 CTC peripheral device providing four 
counter/timer channels, two Z80A PIO devices 
providing 32 programmable I/O lines, and wire wrap 
area for prototyping. The block diagram is 
depicted in Figure 3. Each of the peripherals in 
the development module is connected in a 
prioritized daisy chain configuration. The Z-SCC 
is included in this configuration by tying its IEI 
line to the IEO line of another device, thus 
making it one step lower in interrupt priority 
compared to the other device. 



EXTERNAL 
CLOCK ( 
IN/OUT 
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\( Y BUFFER \f 
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SERIAL 
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Z80A PIO's 
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W W W -rv 



ADDRESS/DATA BUS 



EPROM 

EPROM CONTROL BUS M MEMORY 

(8K WORDS MAX) 



X DYNAMIC A. 

RAM CONTROL BUS ) RAM MEMORY ( 
y (32K WORDS MAX) \f 



Figure 3. Block Diagra. of Z8000 DH 
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Two Z8000 Development Modules containing Z-SCCs 
are connected as shown in Figure 4 and Figure 5. 
The Transmit Data pin of one is connected to the 
Receive Data pin of the other and vice versa. The 
Z8002 is used as a host CPU for loading the 
modules 1 memories with software routines. 



Table 1. Register Nap 



Z8002 
Z-SCC 



TxD__ 
TRxC_ 
RTxC__ 
RxD 



_RxD 
JRTxC 
JRxC 
TxD 



Z8002 
Z-SCC 



Figure 4. Block Diagraa of Two Z80Q0 CPUs 



The Z8002 CPU can address either of the two bytes 
contained in 16-bit words. The CPU uses an even 
address (16 bits) to access the most significant 
byte of a word and an odd address for the least 
significant byte of a word. 

When the Z8002 CPU uses the lower half of the 
Address/Data bus (AD n -AD 7 the least significant 
byte) for byte read and write transactions during 
I/O operations, these transactions are performed 
between the CPU and I/O ports located at odd I/O 
addresses. Since the Z-SCC is attached to the CPU 
on the lower half of the A/D bus, its registers 
must appear to the CPU at odd I/O addresses. To 
achieve this, the Z-SCC can be programmed to 
select its internal registers using lines 
AD1-AD5. This is done either automatically with 
the Force Hardware Reset command in WR9 or by 
sending a Select Shift Left Mode command to WROB 
in channel B of the Z-SCC. For this application, 
the Z-SCC registers are located at I/O port 
address 'FExx'. The Chip Select signal (CSO) is 
derived by decoding I/O address 'FE' hex from 
lines AD3-AD15 of the controller. 



Address 






(hex) 


Write Register 


Read Regisi 


FE01 


WROB 


RROB 


FE03 


WR1B 


RR1B 


FE05 


WR2 


RR2B 


FE07 


WR3B 


RR3B 


FE09 


WR4B 




FEOB 


WR5B 




FEOD 


WR6B 




FEOF 


WR7B 




FE11 


B DATA 


B DATA 


FE13 


WR9 




FE15 


WR10B 


RR10B 


FE17 


WR11B 




FE19 


WR12B 


RR12B 


FE1B 


WR13B 


RR13B 


FE1D 


WR14B 




FE1F 


WR15B 


RR15B 


FE21 


WROA 


RROA 


FE23 


WR1A 


RR1A 


FE25 


WR2 


RR2A 


FE27 


WR3A 


RR3A 


FE29 


WR4A 




FE2B 


WR5A 




FE2D 


WR6A 




FE2F 


WR7A 




FE31 


A DATA 


A DATA 


FE33 


WR9 




FE35 


WR10A 


RR10A 


FE37 


WR11A 




FE39 


WR12A 


RR12A 


FE3B 


WR13A 


RR13A 


FE3D 


WR14A 




FE3F 


WR15A 


RR15A 



INITIALIZATION 



To select the read/write registers automatically, 
the Z-SCC decodes lines AD 1 -AD 5 in Shift Left 
mode. The register map for the Z-SCC is depicted 
in Table 1 . 



The Z-SCC can be initialized for use in different 
modes by setting various bits in its write 
registers. First, a hardware reset must be 
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IAD 15 - 
IAD 14 - 
IAD 13 - 
IAD 12 - 



lADi, - 
IAD 10 - 
IAD9 - 
IAD S " 



IAD7 - 
IADs " 



IADs - 
IAD2 - 
IAD1 - 
lADo - 



GBACAB 



QBAGAB 



AD 14 
AD, 3 
AD 12 



AD,, 
AD, 



AD7 

AD e 



MREQ 
ST 3 
ST 2 
ST, 
ST 



AD3 
AD2 
AD, 
ADq 



WAIT 1 
STOP I 



WAIT 
STOP 
VI 
NVI 




IAD, »— ^O- 



Figure 5. Z8002 With SIX 



performed by setting bits 7 and 6 of WR9 to one; 
the rest of the bits are disabled by writing a 
logic zero. 

SDLC protocol is established by selecting a SDLC 
mode, sync mode enable, and a x1 clock in WR4. A 
data rate of 9600 baud, NRZ encoding, and a 
character length of eight bits are among the other 
options that are selected in this example (Table 
2). 

Note that WR9 is accessed twice, first to perform 
a hardware reset and again at the end of the 
initialization sequence to enable interrupts. The 
programming sequence depicted in Table 2 
establishes the necessary parameters for the 
receiver and transmitter so that they are ready to 
perform communication tasks when enabled. 



Table 2. Programing Sequence 
for Initialization 





Value 




Register 


(hex) 


Effect 


WR9 


CO 


Hardware reset 


WR4 


20 


x1 clock, SDLC mode, sync mode 






enable 


WR10 


80 


NRZ, CRC preset to one 


WR6 


AB 


Any station address e.g. "AB" 


WR7 


7E 


SDLC flag (01111110) = "7E" 


WR2 


20 


Interrupt vector "20" 


WR11 


16 


Tx clock from BRG output, TRxC 






pin = BRG out 


WR12 


CE 


Lower byte of time constant = 






"CE" for 9600 baud 


WR13 





Upper byte =0 


WR14 


03 


BRG source bit = 1 for PCLK as 






input, BRG enable 


WR15 


00 


External Interrupt Disable 


WR5 


60 


Transmit 8 bits/character SDLC 






CRC 


WR3 


C1 


Rx 8 bits/character, Rx enable 






(Automatic Hunt mode) 


WR1 


08 


Rxlnt on 1st char & sp. cond., 






ext int. disable 


WR9 


09 


MIE, VIS, status Low 



The Z8002 CPU must be operated in System mode to 
execute privileged 1/0 instructions. So the Flag 
and Control Word (FCW) should be loaded with 
system normal (S/N), and the Vectored Interrupt 



Enable (VIE) bits set. The Program Status Area 
Pointer (PSAP) is loaded with the address 5S4400 
using the Load Control instruction (LDCTL). If the 
Z8000 Development Module is intended to be used, 
the PSAP need not be loaded by the programmer 
because the development module's monitor loads it 
automatically after the NMI button is pressed. 

Since VIS and Status Low are selected in WR9, the 
vectors listed in Table 3 will be returned during 
the Interrupt Acknowledge cycle. Of the four 
interrupts listed, only two, Ch A. Receive 
Character Available and Ch A Special Receive 
Condition, are used in the example given here. 



Table 3. Interrupt Vectors 





PS 




Vector 


Address* 




(hex) 


(hex) 


Interrupt 


28 


446E 


Ch A Transmit Buffer Empty 


2A 


4472 


Ch A External Status Change 


2C 


4476 


Ch A Receive Char. Available 


2E 


447A 


Ch A Special Receive Condition 



♦Assuming that PSAP has been set to 4400 hex, "PS 
Address" refers to the location in the Program 
Status Area where the service routine address is 
stored for that particular interrupt. 



TRANSMIT OPERATION 

To transmit a block of data, the main program 
calls up the transmit data routine. With this 
routine, each message block to be transmitted is 
stored in memory, beginning with location 'TBUF 1 . 
The number of characters contained in each block 
is determined by the value assigned to the 'COUNT' 
parameter in the main module. 

To prepare for transmission, the routine enables 
the transmitter and selects the Wait On Transmit 
function; it then enables the wait function. The 
Wait On Transmit function indicates to the CPU 
whether or not the Z-SCC is ready to accept data 
from the CPU. If the CPU attempts to send data to 
the Z-SCC when the transmit buffer is full, the 
Z-SCC asserts its Wait line and keeps it Low until 
the buffer is empty. In response, the CPU extends 
its 1/0 cycles until the Wait line goes inactive, 
indicating that the Z-SCC is ready to receive 
data. 
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The CRC generator is reset and the Transmit CRC 
bit is enabled before the First character is sent, 
thus including all the characters sent to the 
Z-SCC in the CRC calculation. 

The Z-SCC 's transmit underrun/EOM latch must be 
reset sometime after the first character is 
transmitted by writing a Reset Tx Underrun/EOM 
command to WRO. When this latch is reset, the 
Z-SCC automatically appends the CRC characters to 
the end of the message in the case of an underrun 
condition. 

Finally, a three-character delay is introduced at 
the end of the transmission, which allows the 
Z-SCC sufficient time to transmit the last data 
byte and two CRC characters before disabling the 
transmitter. 



RECEIVE OPERATION 

Once the Z-SCC is initialized, it can be prepared 
to receive the message. First, the receiver is 
enabled, placing the Z-SCC in Hunt mode and thus 
setting the Sync/Hunt bit in status register RRO 
to 1. In Hunt mode, the receiver searches the 
incoming data stream for flag characters. 
Ordinarily, the receiver transfers all the data 
received between flags to the receive data FIFO. 
If the receiver is in Hunt mode, however, no data 
transfer takes place until an opening flag is 
received. If an abort sequence is received, the 
receiver automatically re-enters Hunt mode. The 
Hunt status of the receiver is reported by the 
Sync/Hunt bit in RRO. 

The second byte of an SDLC frame is assumed by the 
Z-SCC to be the address of the secondary stations 
for which the frame is intended. The Z-SCC 
provides several options for handling this 
address. If the Address Search Mode bit 02 in WR3 
is set to zero, the address recognition logic is 
disabled and all the received data bytes are 
transferred to the receive data FIFO. In this 
mode, software must perform any address recogni- 
tion. If the Address Search Mode bit is set to 
one, only those frames with addresses that match 
the address programmed in WR6 or the global 
address (all 1s) will be transferred to the 
receive data FIFO. If the Sync Character Load 
Inhibit bit (D1) in WR3 is set to zero, the 
address comparison is made across all eight bits 
of WR6. The comparison can be modified so that 



only the four most significant bits of WR6 need 
match the received address. This alteration is 
made by setting the Sync Character Load Inhibit 
bit to one. In this mode, the address field is 
still eight bits wide and is transferred to the 
FIFO in the same manner as the data. In this 
application, the address search is performed. 

When the address match is accomplished, the 
receiver leaves the Hunt mode and establishes the 
Receive Interrupt on First Character mode. Upon 
detection of the receive interrupt, the CPU 
generates an Interrupt Acknowledge Cycle. The 
Z-SCC returns the programmed vector S52C. This 
vector points to the location %4472 in the Program 
Status Area which contains the receive interrupt 
service routine address. 

The receive data routine is called from within the 
receive interrupt service routine. While 
expecting a block of data, the Wait On Receive 
function is enabled. Receive read buffer RR8 is 
read and the characters are stored in memory 
location RBUF. The Z-SCC in SDLC mode auto- 
matically enables the CRC checker for all data 
between opening and closing flags and ignores the 
Receive CRC Enable bit (D3) in WR3. The result of 
the CRC calculation for the entire frame in RR1 
becomes valid only when the End Of Frame bit is 
set in RR1. The processor does not use the CRC 
bytes, because the last two bits of the CRC are 
never transferred to the receive data FIFO and are 
not recoverable. 

When the Z-SCC recognizes the closing flag, the 
contents of the Receive Shift register are 
transferred to the receive data FIFO, the Residue 
Code (not applicable in this application) is 
latched, the CRC error bit is latched in the sta- 
tus FIFO, and the End Of Frame bit is set in the 
receive status FIFO. When the End Of Frame bit 
reaches the top of the FIFO, a special receive 
condition interrupt occurs. The special receive 
condition register RR1 is read to determine the 
result of the CRC calculation. If the CRC error 
bit is zero, the frame received is assumed to be 
correct; if the bit is 1, an error in the 
transmission is indicated. 

Before leaving the interrupt service routine, 
Reset Highest IUS (Interrupt under Service), 
Enable Interrupt on Next Receive Character, and 
Enter Hunt Mode commands are issued to the Z-SCC. 
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If receive overrun error is made, a special 
condition interrupt occurs. The Z-SCC presents 
vector %2E to the CPU, and the service routine 
located at address %447A is executed. Register RR1 
is read to determine which error occurred. 
Appropriate action to correct the error should be 
taken by the user at this point. Error Reset and 
Reset Highest IUS commands are given to the Z-SCC 
before returning to the main program so that the 
other lower-priority interrupts can occur. 

In addition to searching the data stream for 
flags, the receiver also scans for seven 
consecutive 1s, which indicates an abort 
condition. This condition is reported in the 
Break/ Abort bit (D7) in RRO. This is one of many 
possible external status conditions. As a result 



transitions of this bit can be programmed to cause 
an external status interrupt. The abort condition 
is terminated when a zero is received, either by 
itself or as the leading zero of a flag. The 
receiver leaves Hunt mode only when a flag is 
found. 

SOFTWARE 

Software routines are presented in the following 
pages. These routines can be modified to include 
various other options (e.g., SDLC Loop, Digital 
Phase Locked Loop etc.). By modifying the WR10 
register, different encoding methods (e.g., NRZI, 
FMO, FM1) other than NRZ can be used. 
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Appendix 



Software Routines 



plzaam 1.3 
LOC OBJ CODE 



0000 



STMT SOURCE STATEMENT 

1 
2 

3 SDLC NODULE 

5LISTON $TTY 
CONSTANT 

HROA I- %FE21 
RROA i- %PE21 
RBUP i- %5400 
PSAREA i- %4400 
COUNT i- 12 
GLOBAL MAIN PROCEDURE 
ENTRY 



1BASE ADDRESS FOR WRO CHANNEL Al 
1BASE ADDRESS POR RRO CHANNEL Al 
1 BUFFER AREA FOR RECEIVE CHARACTER 1 
1 START ADDRESS FOR PROGRAM STAT AREA1 
1NO. OF CHAR. FOR TRANSMIT ROUTINE 1 



0000 


7601 


LDA 


Rl, PSAREA 




0002 


4400 








0004 


7D1D 


LDCTL 


PSAP0FF,R1 


1LOAD PSAP1 


0006 


2100 


LD 


R0,*%5000 




0008 


5000 








000A 


3310 


LD 


R1(#%1C),R0 


1FCW VALUE (%5000) AT I441C FOR VECTORED I 


000C 


001C 














1 INTERRUPTS 1 


000E 


7600 


LDA 


R0,REC 




0010 


00D6' 








0012 


3310 


LD 


Rl(#%76) ,R0 


1EXT. STATUS SERVICE ADDR. AT %4476 INI 


0014 


0076 
















1PSA1 


0016 


7600 


LDA 


ROrSPCOND 




0018 


OOPA' 








001A 


3310 


LD 


R1(«%7A),R0 


ISP.COND. SERVICE ADDR AT %447A IN PSA I 


001C 


007A 








001E 


5F00 


CALL 


INIT 




0020 


0034' 








0022 


5P00 


CALL 


TRANSMIT 




0024 


008C 








0026 


E8PP 


JR 


$ 




0028 


AB 


TBUPt BVAL 


%AB 


I STATION ADDRESS 1 


0029 


48 


BVAL 


'H' 




002A 


45 


BVAL 






002B 


4C 


BVAL 


•L' 




002C 


4C 


BVAL 


'L« 




002D 


4F 


BVAL 


•0' 




002E 


20 


BVAL 


i i 




002F 


54 


BVAL 


iipt 




0030 


48 


BVAL 


• H « 




0031 


45 


BVAL 


• E« 




0032 


52 


BVAL 


'R' 




0033 


45 


BVAL 


•E' 




0034 




END 


MAIN 
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1 ****************** INITIALIZATION ROUTINE FOR Z-SCC 



1 



0034 




GLOBAL INIT 
ENTRY 


PROCEDURE 




0034 


2100 


LD 


R0,#15 


1NO.OP PORTS TO WRITE TO I 


0036 


000F 








0038 


7602 


LDA 


R2,SCCTAB 


I ADDRESS OP DATA POR PORTS 1 


003A 


004E' 








003C 


2101 


ALOOPi LD 


R1,#WR0A 




003E 


PE21 








0040 


0029 


ADOB 


RL1,§R2 




0042 


A920 


INC 


R2 




0044 


3A22 


OUTIB 


§R1,§R2,R0 


1 POINT TO WR0A r WRlA ETC THRO LOOP! 


0046 


0018 








0048 


8D04 


TEST 


R0 


1END OF LOOP? I 


004A 


EEP8 


JR 


NZ,ALOOP 


1 NO r KEEP LOOPING 1 


004C 


9E08 


RET 






004E 


12 


SCCTABi BVAL 


2*9 




004F 


CO 


BVAL 


ICO 


1 WR9"> HARDWARE RESET! 


0050 


08 


BVAL 


2*4 




0051 


20 


BVAL 


%20 


IWR4-X1 CLK, SDLC, SYNC NODE! 


0052 


14 


BVAL 


2*10 




0053 


80 


BVAL 


180 


IWR10-CRC PRESET ONE, NRZ, FLAG ON IDLE, 1 
I FLAG ON UNDERRUNI 


0054 


OC 


BVAL 


2*6 




0055 


AB 


BVAL 


%AB 


IWR6- ANY ADDRESS FOR SDLC STATION! 


0056 


OE 


BVAL 


2*7 




0057 


7E 


BVAL 


%7E 


1WR7-SDLC FLAG CHAR1 


0058 


04 


BVAL 


2*2 




0059 


20 


BVAL 


120 


1WR2-INT VECTOR 120! 


005A 


16 


BVAL 


2*11 




005B 


16 


BVAL 


116 


IWRll-Tx CLOCK & TRjtC OUT-BRG OUT! 


005C 


18 


BVAL 


2*12 




005D 


CE 


BVAL 


%CE 


1WR12- LOWER TC-CEI 


005E 


1A 


BVAL 


2*13 




005P 


00 


BVAL 





IWR13- UPPER TC-01 


0060 


1C 


BVAL 


2*14 




0061 


03 


BVAL 


103 


1WR14-BRG ON,BRG SROPCLKl 


0062 


IE 


BVAL 


2*15 




0063 


00 


BVAL 


100 


IWR15-EXT INT. DISABLE! 


0064 


OA 


BVAL 


2*5 




0065 


60 


BVAL 


%60 


1WR5-TX 8 BITS/CHAR, SDLC CRC! 


0066 


06 


BVAL 


2*3 




0067 


C5 


BVAL 


%C5 


1WR3-ADDR SRCH,REC ENABLE! 


0068 


02 


BVAL 


2*1 




0069 


08 


BVAL 


%08 


1WR1-RX INT ON 1ST & SP COND,! 
1EXT INT DISABLE! 


006A 


12 


BVAL 


2*9 




006B 


09 


BVAL 


%09 


1WR9- HIE, VIS, STATUS LOW! 


006C 




END INIT 







I****************** RECEIVE ROUTINE ************************************! 



! RECEIVE A BLOCK OP MESSAGE 1 



006C 




GLOBAL RECEIVE 
ENTRY 


PROCEDURE 




006C 


C828 


LDB 


RL0,#%28 


1WAIT ON RECV.l 


006B 


3A86 


OUTB 


WR0A+2,RL0 




0070 


FE23 








0072 


6008 


LDB 


RL0,%A8 




0074 


0OA8 








0076 


3A86 


OUTB 


WR0A+2,RL0 


1 ENABLE WAIT PNC. SP. COND. INT! 


0078 


FE23 








007A 


2101 


LD 


R1,#RR0A+16 




007C 


FE31 








007E 


2102 


LD 


R2,#COUNT+2 


1COUNT+2 CHARACTERS TO READ! 


0080 


00OE 








0082 


2103 


LD 


R3,#RBUP 


1 RECEIVE BUPFER IN MEMORY! 


0084 


5400 








0086 


3A18 


INDRB 


§R3,8R1,R2 


1READ THE ENTIRE MESSAGE! 


0088 


0230 








008A 


9E08 


RET 






008C 




END RECEIVE 
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I**************** 

I 
I 



TRANSMIT ROUTINE ************************************ J 



SEND A BLOCK OF EIGHT DATA CHARACTERS 
THE BLOCK STARTS AT LOCATION TBUF 



008C 

008C 2102 
008E 0028' 
0090 C868 
0092 3A86 
0094 FE2B 
0096 C800 
0098 3A86 
009A FE23 
009C C888 
009E 3A86 
00A0 FE23 
00A2 C880 
00A4 3A86 
00A6 FE21 
00A8 2101 
00AA FE31 
00AC 2100 
OOAE 0001 
00B0 C869 
00B2 3A86 
00B4 FE2B 
00B6 3A22 
00B8 0010 
OOBA C8C0 
OOBC 3A86 
OOBE FE21 
00C0 2100 
00C2 000B 
00C4 3A22 
00C6 0010 
00C8 2100 
OOCA 039E 
OOCC F081 
OOCE C800 
00D0 3A86 
00D2 FE2B 
00D4 9E08 
00D6 



GLOBAL 
ENTRY 



TRANSMIT PROCEDURE 



DEL I 



END TRANSMIT 



LD 


R2 , *TBUF 


IPTR TO START OF BUFFER 1 


LDB 
OUTB 


RL0,#%68 
WROA+10 f RLO 


1 ENABLE TRANSMITTER 1 


LDB 
OUTB 


RLO , #%00 
WR0A+2,RL0 


1WAIT ON TRANSMIT 1 


LDB 
OUTB 


RL0 r t%88 
WR0A+2,RL0 


1WAIT ENABLE I 


LDB 
OUTB 


RL0 f #%80 
WROA, RLO 


1 RESET TxCRC GENERATOR 1 


LD 


R1,*WR0A+16 


1WR8A SELECTED 1 


LD 


R0,*1 




LDB 
OUTB 


RL0,t%69 
WROA+10, RLO 


1SDLC CRC1 
!WR5A-TxCRC ENABLE I 


OTIRB 


§R1,8R2,R0 


1SEND ADDRESS I 


LDB 
OUTB 


RL0,t%C0 
WROA, RLO 


1 RESET TxUND/EOM LATCH 1 


LD 


RO , ICOUNT-1 




OTIRB 


@R1,@R2,R0 


1SEND MESSAGE 1 


LD 


R0 r *926 


1 CREATE DELAY BEFORE DISABLING 1 


DJNZ 

LDB 

OUTB 


RO r DEL 
RL0,*0 
WROA+10, RLO 


I TRANSMITTER SO THAT CRC CAN BE I 
1SENT1 

1 DISABLE TRANSMITTER! 


RET 







I************* RECEIVE INT. SERVICE ROUTINE *************************! 



00D6 




GLOBAL REC 
ENTRY 


PROCEDURE 




00D6 


93F3 


PUSH 


@R15,R3 




00D8 


93F2 


PUSH 


§R15,R2 




OODA 


93F1 


PUSH 


§R15,R1 




OODC 


93F0 


PUSH 


§R15,R0 




OODE 


3A94 


INB 


RL1,RR0A 


I READ STATUS REG RR0A1 


00E0 


FE21 








00E2 


A690 


BITB 


RLl r #0 


1TEST IF Rx CHAR SET1 


00E4 


E602 


JR 


Z, RESET 


I YES CALL RECEIVE ROUTINE 1 


00E6 
00E8 


5F00 
006C 


CALL 


RECEIVE 




OOEA 


C838 


RESET: LDB 


RL0,#%38 




OOEC 


3A86 


OUTB 


WR0A,RL0 


1 RESET HIGHEST IUS1 


OOEE 


FE21 








00F0 


97F0 


POP 


R0,8R15 




00F2 


97F1 


POP 


R1,@R15 




00F4 


97F2 


POP 


R2,§R15 




00F6 


97F3 


POP 


R3,@R15 




00F8 


7B00 


IRET 







OOFA END REC 
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1 ************ SPECIAL CONDITION INTERRUPT SERVICE ROUTINE ***************! 



GLOBAL SPCOND PROCEDURE 
ENTRY 



OOFA 93P0 


PUSH 


@R15,R0 




OOPC 3A84 


INB 


RL0,RR0A+2 


1READ ERRORS 1 


OOFE PE23 








QlOO A687 


BITB 


RL0,#7 


1 ENI) OP FRAME ? I 




1 PROCESS OVERRUN, FRAMING ERRORS 


IF ANY 1 


0102 E603 


JR 


Z r RESE 




0104 C820 


LDB 


RL0 r #%20 




0106 3A86 


OUTB 


HROArRLO 


1 YES t ENABLE INT ON 


0108 FE21 








010A C830 


RESEt LDB 


RL0,*%30 




010C 3A86 


OUTB 


WROAf RLO 


1 ERROR RESET 1 


010E FE21 








0110 C808 


LDB 


RL0,#%08 




0112 3A86 


OUTB 


WR0A+2,RL0 


1WAIT DISABLE, RxINT 


0114 FE23 








0116 C838 


LDB 


RL0,#%38 




0118 3A86 


OUTB 


WR0A,RL0 


1 RESET HIGHEST IUS1 


011A FE21 








011C 97P0 


POP 


R0,§R15 




011E 7B00 


IRET 







0120 



END SPCOND 
END SDLC 
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Boost your System Performance using The Zilog ESCC 



For greater testability, larger interface flexibility, and increased CPU/DMA offloading, 
replace the SCC with the ESCCT Controller ...and utilize the ESCC to its full potential. 



INTRODUCTION 

This App Note (Application Note) describes the differences 
between the SCC (Z8030/8530, Z80C30/85C30) and ESCC 
(Z80230/85230). It outlines the procedures in utilizing the 
ESCC to its full potential. Application details such as Sche- 
matics and Program Listings are not included since these 
materials are in our various application support products. 

Note: The author assumes the audience has fundamental 
Datacommunications knowledge and basic familiarity with 
Zilog SCC products. 



ESCC/SCC DIFFERENCES 




The differences between the ESCC and SCC are shown 
below: 




ESCC ENHANCEMENT 


PERFORMANCE BENEFITS 


1 . Extended Read Enable of Write Registers 

2. Hardware Improvement 

- Modified WRITE Timing 

- Modified DMA Request on 

- Transmit Deactivation Timing 


- Improves Testability 

- Ability to examine SDLC status on-the-fly 

- Improves Interface to 80X86 CPU 

- Improves Interface DMA-driven system 


3. Throughput improvement 

- Deeper Transmit FIFO 

- Deeper Receive FIFO 

- FIFO Interrupt Level 


- Reduces TBE Interrupt Frequency by 3/4 

- Reduces RCA Interrupt Frequency by 3/4 

- Flexibility in Adapting CPU Workload 


4. SDLC End Of Frame Improvement 

- Automatic RTS Deassertion after Closing Flag 

- Automatic Opening Flag Transmission 

- AutomaticTxD Forced High in SDLC with NRZI Encod- 
ing When Marking Idle After End Of Frame 

- Improvement to Allow Transmission of Back-to-Back 
Frames with a Shared Flag 

- Status FIFO Anti-Lock Feature in DMA-Driven 
System 


- Reduces CPU and DMA Controller Overhead 
after End Of Frame 

- Allows Optimal SDLC Line Utilization 
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Notes: 

All Signals with a preceding front slash, 7, are active Low, e.g.: 
B//W (WORD is active Low); /B/W (BYTE is active Low, only). 

Power connections follow conventional descriptions below: 

Connection Circuit Device 

Power V cc V DD 

Ground GND V cc 



ESCC/SCC DIFFERENCES (Continued) 



The differences between the ESCC and SCC are summa- 
rized by a new register, WR7' (Figure 1). 



D7 



D5 I D4 I D3 I D2 



1 1 D1 | DO | 



Auto Tx Flag 
Auto EOM Reset 
Auto RTS Deactivate 
Rx FIFO Int Level 
DTR/REQ Timing 
Tx FIFO Int Level 
Extended RD Enable 
Not Used, Always 



The advantages of the new features are illustrated in the 
following examples. 

One of the features that is offered by the ESCC, but not the 
SCC, is Extended Read Enable. Write Register values from 
the WR3, WR4, WR5, WR7', and WR10 can be examined 
in the ESCC but not the SCC. This feature improves system 
testability. It is also crucial for SCC/ESCC differentiation 
and allows generic software structures for all SCC/ESCC 
devices. 

Flowchart 1 (Figure 2) shows a generic software structure 
applicable for all SCC/ESCC initializations. Flowchart 2 
(Figure 3) suggests a method for determining which type 
of SCC/ESCC™ device is in the socket. This software 
structure helps the development of software drivers inde- 
pendent of the device type. 



Addressing: 
WR15D0-*— '1' 
WR7 'XX' 



Figure 1. WR7' Definition 




Determine 
SCC/ESCC Type 



SCC 
Z85C30 



© 



ESCC 
Z85230 



Z85C30 
Initialization 



Z85230 
Initialization 



Figure 2. Generic SCC/ESCC Drivers 
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Figure 3. SCC/ESCC Differentiation Flowchart 



ESCC SYSTEM BENEFITS 

The Software Overhead sets the System Performance 
Limits. The ESCC's deeper FIFOs and other features 
significantly reduce the software overhead for each chan- 
nel. This allows: 

■ More Channels Per System 

■ Faster Data Rates on Channels 

■ More CPU bandwidth available for other tasks 

■ Lower CPU Costs 
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ESCC SYSTEM BENEFITS (Continued) 



Data Flow 



sec 



Interrupt 



System 



Data Flow 



Interrupt 



ESCC 

Interrupt Frequency Reduction 



System 



SCC Systems 

Other CPU Tasks — — 

Transmit Data _ 
Interrupt Overhead — — — — 



Time 



ESCC Systems 

Other CPU Tasks , 

Additional Performance + 

Transmit Data 
Interrupt Overhead 

Time 



ESCC Reduces System Workload and Allows Extra Performance 
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TRANSMIT FIFO INTERRUPT 



In the ESCC, transmit interrupt frequencies are reduced by 
a deeper Transmit FIFO and the revised transmit interrupt 
structure. If the WR7' D5 Transmit FIFO Interrupt Level bit 
is reset, the transmit interrupt is generated when the entry 
location of the FIFO is empty, i.e., more data can be written. 
This is downward compatible with a SCO Transmit Interrupt 
since the SCO only has a one-byte transmit buffer instead 
of a four-byte Transmit FIFO. 



If WR7' D5 is set, the transmit buffer empty interrupt is 
generated when the transmit FIFO is completely empty. 
Enabling the transmit FIFO interrupt level, together with 
polling the Transmit Buffer Empty (TBE) bit in RRO, causes 
significanttransmit interrupt frequency reduction. Transmit 
data is sent in blocks of four bytes (algorithm is illustrated 
in Figure 4). This helps to offload those systems which have 
long interrupt latency or a fully loaded Operating System. 



TX FIFO Int. 
Level Enabled 



TBE Interrupt 
Service 




Transmit FIFO 
Is Loaded 
With Data 



Figure 4. Flowchart of Transmit Interrupt Service Routine 
to Reduce Transmit Interrupt Frequencies 
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RECEIVE FIFO INTERRUPT 



In the ESCC, receive interrupt frequencies are reduced 
due to a deeper Receive FIFO and the revised receive 
interrupt structure. 

If WR7' D3 Receive FIFO Interrupt Level bit is reset, the 
ESCC generates the receive character available interrupt 
on every received character. This is compatible with SCC 
Receive Character Available Interrupt. If WR7' D3 is set, 



the Receive Character Available Interrupt is triggered 
when the Receive FIFO is half full; the first four locations 
from the entry are still empty. By enabling the receive FIFO 
interrupt level, together with polling the Receive Character 
Available (RCA) bit in RRO, the receive interrupt frequen- 
cies are reduced significantly. Receive data is read in 
blocks of four bytes (Figure 5). This would help to offload 
systems which have a long interrupt latency and heavily 
loaded Operating Systems. 



RX FIFO Int. 
Level Enabled 



RCA Interrupt 
Service 




All Data in 
RX FIFO Have 
Been Read 



Figure 5. Flowchart of Receive Interrupt Service Routine 
to Reduce Receive Interrupt Frequencies 
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AUTOMATIC /RTS DEASSERTION 



Several SDLC enhancements are provided in the ESCC. 
The ESCC allows automatic /RTS deassertion at End Of 
Frame (EOF). The automatic /RTS deassertion is enabled 
by setting WR7' D2. If ESCC is programmed for SDLC 
mode and the Flag-On-Underrun bit (WR10 D2) is reset, 
with the RTS bit (WR5 D1) reset, /RTS is deasserted 
automatically at the last bit of the closing flag . It is triggered 
by the rising edge of the Transmit Clock (TxC - Figures 6 
and 7). 

/RTS is normally used in SDLC for switching the direction 
of line drivers. Automatic /RTS deassertion allows optimal 

Data Being Sent 



line switching without any software intervention/The typi- 
cal procedures are as follows: 



1 . Enable Automatic /RTS Deassertion 

2. Before frame transmission, set RTS bit 

3. Enable frame transmission 

4. Reset RTS bit 

5. /RTS pin deassertion is delayed until the last rising TxC 
edge closing flag. 



Data 
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Figure 6. /RTS Deassertion Timing 
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Figure 7. /RTS Deassertion Sequence 



7-119 



AUTOMATIC OPENING FLAG TRANSMISSION 



When Auto Tx Flag (WR7\ DO) is enabled, the ESCC 
automatically transmits a SDLC opening flag before trans- 
mitting data. This removes: 

1. Requirements to reset the mark idle bit (WR10 D3) 
before writing data to the transmitter, or; 

2. Waiting for eight bit times to load the opening flag. 

TxD Forced High In SDLC With NRZI Encoding 
When Marking Idle After End Of Frame 

When the ESCC is programmed for SDLC mode with NRZI 
encoding and mark idle (WR10 D6=0,D5=1 ,D3=1), TxD is 
automatically forced high when the transmitter goes to the 
mark idle state at EOF or when Abort is detected. This 
feature is used in combination with the automatic SDLC 
opening flag transmission to format the data packets 
between successive frames properly without any require- 
ment in software intervention. 



Status FIFO Enhancement 

ESCC SDLC Frame Status FIFO implementation has been 
improved to maximize ESCC ability to interface with a 
DMA-driven system (Technical Manual, 4.4.3). The Status 
FIFO and its relationship with RR1 , RR6 and RR7 is shown 
in Figure 8. 

Other special conditions (e.g., Overrun) generates special 
receive conditions and lock the Receiver FIFO (Figures 9 
and 10). 
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Figure 8. Status FIFO 
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SDLC Frame Status FIFO enhancement is enabled by 
setting WR15 D2. If it is enabled when EOF is detected, 
byte count and status from the Status FIFO are loaded into 
RR6, RR7 and RR1 . This is used in DMA-driven systems. 
Historically, EOF is treated as a special condition. Special 
condition interrupts are triggered if any one of the below 
interrupts is enabled: 

1. Receive Interrupt on First Character or Special 
Condition. 

2. Interrupt on All Receive Characters or Special 
Conditions. 

3. Special Receive Condition Only. 

If 1 or 3 (above) is enabled, the data FIFO is locked after 
the interrupt is serviced by reading RR1 in the Status FIFO, 
as shown in Figure 1 1 . This is commonly used in a DMA- 
driven system to avoid delivering useless information 
(e.g., EOF) to the data buffer. Locking the data FIFO is not 
desirable in systems with long interrupt latency and high 
data rate communications. The reason is the ERROR 
RESET command is necessary to unlock the FIFO. Data 
from the next frame may be lost if ERROR RESET fails to 
issue early. 



This drawback is improved in the ESCC for a DMA driven 
system. By enabling interrupts on "Special Receive 
Conditions only" and SDLC status FIFO, EOF is treated 
differently from other special conditions. When EOF status 
reached the exit location of the FIFO: 

1 . A "Receive Data Available" interrupt is generated to 
signal that EOF has been reached. 

2. Receive Data FIFO is not locked. 

Because of these changes, the data from the next frame is 
securely loaded and the system processes the EOF 
interrupt. The only responsibility of the software is issuing 
the Reset Highest IUS before resuming normal operation 
(Figure 12). 
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Figure 9. Status FIFO Operation at End Of Frame 
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Status FIFO Enhancement (Continued) 
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1 >. Enable Receive Interrupt on Special Conditions only. 

2. Receive Data FIFO not locked. 

3. Receive Character Available Interrupt generated 

even if it has not been enabled to indicate detection of EOF. 



1. Enable Receive Interrupt on Special Conditions only. 

2. Receive Data FIFO locked. 

3. Special Condition Interrupt generated. 



Figure 10. SDLC Status FIFO Anti-Lock 
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Figure 11. Receive Interrupt Mechanism 1 
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Figure 12. Receive Interrupt Mechanism 2 



DMA Request on Transmit Deactivation 
Timing /DTR//REQ. 

Timing implementation in the ESCC has been improved to 
make it more compatible with the DMA cycle timing (Ref- 
erence Tech Manual, Section 2.5.2; DMA Request on 
Transmit). 

Transmission of Back-To-Back Frames 
With a Shared Flag. 

The ESCC provides facilities to allow transmission of back- 
to-back frames with a shared flag between frames 
(Figure 13). 

In the ESCC, if the Automatic End Of Message (EOM) 
Reset feature is enabled (WR7' D1=1), data for a second 
frame is written to the transmit FIFO when Tx Underrun/ 
EOM interrupt has occurred. This allows application soft- 
ware sufficient time to write the data to the transmit FIFO 
while allowing the current frame to be concluded with CRC 
and flag. 



In the SCC, Transmission of Back-to-Back Frames is more 
difficult because (Figure 14): 

1 . Data cannot be written to the transmitter at EOF until a 
Transmit Buffer Empty interrupt is generated after 
CRC has completed transmission. 

2. Automatic EOM Reset is not available in the SCC. 
Application software has to issue the "Reset Tx/ 
Underrun EOM" command manually. The software 
overhead limits the next frame data to deliver immedi- 
ately after the preceding frame has been concluded 
with CRC and Flag. 



i 
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Transmission of Back-To-Back Frames 
With a Shared Flag (Continued) 



Requirements: Automatic EOM Reset and Automatic Opening Flag features are enabled. 
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Figure 13. Transmission of Back-to-Back Frames with a Shared Flag 
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Figure 14. Operation of Shared Flag Transmission 



7-124 



Modified Write Timing 



In the SCC write cycle, the SCC assumes the data is valid 
when /WR is asserted (Figure 15). This assumption is not 
valid for some CPUs, e.g., the Intel 80X86. The /WR signal 
from this CPU needs to delay for one more clock to initiate 
the write cycle. Additional hardware is required. 



In the ESCC, write cycle timing has been modified so that 
data becomes valid a short time after write (approx. 20 ns). 
Therefore, if the data pins from the Intel CPU are con- 
nected directly to the ESCC, no additional logic is re- 
quired. 
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Figure 15. Modified Write Timing 
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Technical Considerations When Implementing 
localtalk link access protocol 



rhe LLAP Protocol is an important part of the Appletalk network system. It manages access 
to the node-to-node transmission of network data packets, governs access to the link, and 
provides a means for nodes to discover valid addresses... all error free. 



INTRODUCTION 

The LLAP (LocalTalk Link Access Protocol) is the ISO/OSI 
(International Standards Organization/Open Systems 
Interconnection) link layer protocol of the AppleTalk network 
system. This protocol manages the node-to-node 
transmission of data packets in the network. LLAP governs 
access to the link and provides a means for nodes to 
discover valid addresses. It does not guarantee packet 
delivery; it does guarantee that those packets that are 
delivered are error-free. 



Some of the problems of transmitting and receiving LLAP 
frames are discussed, using sample code written for 
Zilog's Z80181 Emulation Adapter Board. This App Note 
(Application Note) does not address the architectural 
issues of writing a driver but it does focus on the details of 
using an SCC to send and receive LLAP frames. The 
problems of sending sync pulses, timing transmissions 
and determining that a frame has been received properly 
are discussed. 



GENERAL DESCRIPTION 

The LocalTalk Link Access Protocol (LLAP) is the ISO-OSI 
link layer protocol of the AppleTalk network system using 
LocalTalk. Along with ELAP (the corresponding Ethernet 
link layer protocol) and TLAP (the Token Ring link layer 
protocol), it provides the foundations upon which the other 
protocols rest. The LLAP protocol supports the node-to- 
node transmission of packets used by DDP and RTMP to 
route packets around the internetwork; DDP, in turn, 
supports the name binding functions of NBP, the reliable 
frame delivery of ATP, and the rest of the AppleTalk 
protocol stack. 



A majority of the difficult timing and all of the hardware 
interface problems crop up in the LLAP driver. These 
problems are so difficult that it makes sense to start writing 
such a driver by writing experimental routines that transmit 
and receive frames. Also, this App Note deals with the 
intricacies of the interframe and interdialog timings before 
trying to engineer code that will truly be a driver. Some of 
the experimental routines to run on the Z80181 Emulation 
Adapter Board are explained. 
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GENERAL DESCRIPTION (Continued) 



The LLAP provides the basic transmission of packets from 
one node to another on the same network. LLAP accepts 
packets of data from clients residing on a particular node 
and encapsulates that data into its proper LLAP data 
packet. The encapsulation includes source and destination 
addresses for proper delivery. LLAP ensures that any 
damaged packet is discarded and rejected by the 
destination node. The LLAP makes no effort to deliver 
damaged packets. 

Carrier Sense Multiple Access with Collision 
Avoidance 

It is LLAP's responsibility to provide proper link access 
management to ensure fair access to the link by all nodes 
on that network. The access discipline that governs this is 
known as Carrier Sense Multiple Access with Collision 
Avoidance (CSMA/CA). A node wishing to gain access to 
the link must first sense that the link is not in use by any 
other node (carrier sense); if the link has activity, then the 
node wishing to transmit must defer transmission. The 
ability of LLAP to allow multiple access to the link also 
leaves room for possible collisions with other data packets. 
LLAP attempts to minimize this probability (collision 
avoidance). 

Two techniques are used by LLAP in its implementations 
of CSMA/CA. LLAP outlines this procedure but falls short 
in endorsing which hardware to use. (The SCC is, of 
course, used byApple.)Thefirsttechnique takes advantage 
of the distinctive 01111110 flag bytes that encapsulate the 
data packet (note that this implies that SDLC is used). 
LLAP stipulates that a minimum of two flags precede each 
of these data packets. The leading flag characters provide 
byte synchronization and give a clue to any listener that 
some other node is using the link at a particular time (use 
the Hunt bit in RR0 if the SCC is used). 

In SDLC mode, the receiver automatically synchronizes on 
the flag byte and resets the Hunt bit to zero. The SCC has 
some latency in detecting these flag bytes due to the 
shifter, etc. This is not ideal because the node needing to 
transmit may determine that the link is free, when in fact the 
flag bytes are still being shifted into its receiver (i.e., the link 
is not idle at all). 



A closing flag is also needed to fully encapsulate the data 
packet. LLAP requires that 12 to 18 ones be sent after this 
closing flag. The LocalTalk hardware (i.e., the SCC) 
interprets this as an abort sequence and causes the 
node's hardware to lose byte sync; this then confirms that 
the current sender's transmission is oyer. In SDLC mode, 
seven or more contiguous 1 's in the receive data stream 
forces the receiver into Hunt (Hunt bit set) and an External/ 
Status interrupt can be generated. This is important 
because the node wishing to use the bus can simply wait 
for this interrupt before preparing to transmit it's packet. 

LLAP uses a second technique in its carrier sensing. LLAP 
requires that a synchronization pulse for an idle period of 
at least two bit times be transmitted prior to sending the 
RTS handshaking frame (Figure 1 ). This synchronization is 
obtained by first enabling the hardware line so that an 
edge is detected by all the receivers on the network. This 
initial edge is perceived as the beginning of the clocking 
period. It is soon followed by an idle period (a period with 
no carrier) of at least two bit times. All the receivers on the 
network see this idle period and assume that the clock has 
been lost (missing clock bit set on RR10 ). This method is 
much more immediate than the byte flag synchronization 
method and provides a quicker way of determining whether 
the link is in use. Unfortunately, an interrupt is not generated 
by this missing clock and, therefore, polling must be 
implemented. 

The Z80181 code used for polling the missing clock bit is 
approximately fifty clock cycles which at 10 MHz is about 
5 |isec or about one bit time. This is still relatively quicker 
than the time required for the SCC to reset the Hunt bit (the 
flag character takes at least eight bit times for it to be 
shifted through the buffer before the Hunt bit is reset to 
zero). Synchronization pulses can be sent before every 
frame but because of the time constraints associated with 
the interframe gaps it makes sense to send such pulses 
only before the lapENQ and lapRTS frames. 
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Figure 1. CSMA/CA Synchronization Pulse Timing Diagram 



Dynamic Node ID 

LLAP requires the use of an 8-bit node identifier number 
(node ID) for each node on the link. Apple had decided 
that all LLAP nodes must have a dynamically assigned 
node ID. A node would assign itself its unique address 
upon activation. It is then up to that particular node to 
ascertain that the address it had chosen is unique. A node 
randomly chooses an 8-bit address (for example, the 
refresh register value on the Z801 81 is added to a randomly 
chosen value on the receive buffer to obtain a pseudo 
random 8-bit address). 

The node then sends out an LLAP Enquiry control packet 
to all the other nodes and waits for the prescribed 
interframe gap of 200 usee. If another node is already 
using this node ID, then that node must respond within 200 
usee with a LLAP Acknowledgement control packet. The 
new node must then rebroadcast a new guess for its node 
ID. If a LLAP Acknowledgement packet is not received 
within 200 usee then the new node assumes that the 
address is indeed unique. The new node must rebroadcast 
the LLAP enquiry packet several more times to account for 
cases when the packet could have been lost or when the 
guessed node ID is busy and could have missed the 
Enquiry packet. 

LLAP Packet 

LLAP packets are made up of three header bytes 
(destination ID, source ID and LLAP type) and to 600 
bytes of variable length data. The LLAP type indicates the 
type of packet that is being sent. 80H to FFH are reserved 
as LLAP control packets. The four LLAP control packets 
that are currently being used are: The lapENQ, which is 
used as enquiry packet for dynamic node assignments; 
the lapACK, which is the acknowledgementto the lapENQ; 



the lapRTS, which is the request to send packet that 
notifies the destination of a pending transmission; and the 
lapCTS, which is the clear-to-send packet in response to 
the RTS packet. Control packets do not contain data 
fields. 

LLAP Packet Transmission 

LLAP distinguishes between two types of transmissions: a 
directed packet is sent from the source node to a specific 
destination node via a directed transmission dialog; a 
broadcast packet is sent from the source node to all nodes 
on the link (destination ID is FFH) via a broadcast 
transmission dialog. All dialogs must be separated by a 
minimum Inter Dialog Gap (IDG) of 400 usee. Frames 
within these dialogs must be separated from each other 
with a maximum Inter Frame Gap (IFG) of 200 usee. 

The source node uses the physical layer to detect the 
presence or the absence of data packets on the link. The 
node will wait until the line is no longer busy before 
attempting to send its packets. If the node senses that the 
line is indeed busy, then this node must defer. When the 
node senses that the line is idle, then the node waits the 
minimum IDG plus some randomly generated time before 
sending the packet (the line must remain idle throughout 
this period before attempting to send the packet). The 
initial packets to be sent are handshaking packets. The 
first packet sent by the source node to its destination node 
is the RTS packet. The receiver of this RTS packet must 
return a CTS packet within the allowable maximum IFG. 
The source node then starts transmitting the rest of its data 
packet upon receiving this CTS. 
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GENERAL DESCRIPTION (Continued) 



Collisions are more likely to occur during the handshaking 
phase of the dialog. The randomly generated time that is 
added to the IDG tends to help spread out the use of the 
link among all the transmitters. A successful RTS to CTS 
handshake signifies that a collision did not take place. An 
RTS packet that collides with another frame has corrupt 
data that shows up as a CRC error on the receiving or the 
destination node. Upon receiving this, the destination 
node infers that a collision must have taken place and 
abstains from sending its CTS packet. The source or the 
transmitting node sees that the CTS packet was not received 
during the IFG and also infers that a collision did take 
place. The sending node then backs off and retries. 

The LLAP keeps two history bytes that log the number of 
deferrals and collisions during a dialog. These history 
bytes help determine the randomly generated time that is 
added to the IDG. The randomly generated time is 



readjusted according to the traffic conditions that are 
present on the link. If collisions or deferrals have just 
occurred on the most recently sent packets, then it can be 
assumed that the link has heavier than usual traffic. Here, 
the randomly generated number should be a larger number 
in order to help spread out the transmission attempts. 
Similarly, if the traffic is not so great, then the randomly 
generated number should be smaller, thus reducing the 
dispersion. of the transmission attempts. 

LocalTalk Physical Layer 

LocalTalk uses the SDLC format and the FMO bit encoding 
technique. The RS-422 signalling standard for transmission 
and reception was chosen over the RS-232 because a 
higher data rate over a longer physical distance is required. 
LocalTalk requires signals at 230.4 Kbits per second over 
a distance of 300 meters. 



HARDWARE CONFIGURATION 

As shown in Figure 2, the hardware used to implement this 
LLAP driver consists of the Z80181 (an integration of the 
Z80180 compatible MPU core with one channel of a 
Z85C30 SCC, Z80 CTC, two 8-bit general purpose parallel 
ports and two chip select signals) operating at 10 MHz, 
a 3.6864 MHz clock source and an RS-422 line driver with 
tri-state. 

The SCC's clocking scheme decouples the 
microprocessor's clock from the communication clock 
(Figure 3). The DPLL uses the /RTxC pin as its source. The 
/RTxC also drives the Baud Rate Generator which divides 
its input by sixteen. The resulting 230.4 kHz signal is then 



used as transmitter clock. This 230.4 kHz signal is also 
used by one of the Z80181 's counter/timer trigger inputs 
(Z80 CTC's channel 1) which is used to count the number 
of elapsed bit times. In counter mode, each active edge to 
the CTC's CLK/TRG 1 input causes the downcounter of the 
CTC to be decremented. The /TRxC pin is programmed as 
BRG output and is connected to the CLK/TRG 1 input via an 
external wire. 

The /RTS signal is used to tri-state RS-422 to allow other 
node transmitters to drive the line. This signal is asserted 
and deasserted via bit1 of the SCC's Write Register 5. 
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HARDWARE CONFIGURATION (Continued) 



Listing 1 (Reference Appendix A for Listings 1 through 4) 
shows the assembler code for this SCC initialization. Note 
that the SCC is treated as a peripheral by the Z80181's 
MPU. For example, an I/O write to the scc_cont (address 
e8H) or to the scc_data (address e9H) is a write to the 
SCC's control and data registers, respectively. As shown 
in Listing 1 , the SCC is initialized by issuing I/O writes to the 
pointer and then to the control registers in an alternating 
fashion. It is therefore very important that all interrupts are 
disabled during this initialization routine. 

The SCC is initially reset via software before proceeding to 
program the other write registers. A NOP is sufficient to 
provide the four PCLKs required by the SCC recovery time 
after a soft reset. The SCC is programmed for SDLC mode. 
The receive, transmit and external interrupts are all initially 
disabled during this initialization. Each of these interrupt 
sources are enabled at their proper times in the main 
program. The SCC is programmed to include status 
information in the vector that it places on the bus in 
response to an interrupt acknowledge cycle (see Listing 4 
of the SCC interrupt vector table for all the possible 
sources). 



Since SDLC is bit-oriented, the transmitter and receiver 
are both programmed for 8 bits per character as required 
by LLAP. Address filtering is implemented by setting the 
Address Search Mode bit 2 on WR3. Setting this bit causes 
messages with addresses not matching the address 
programmed in WR6 and not matching the broadcast 
address to be rejected. Values in WR10 presets the CRCs 
to ones, sets the encoding to FMO mode and makes 
certain that transmission of flags occur during idle and 
underrun conditions. WR11 is set so that the receive clock 
is sourced by the DPLL output; the transmit clock is 
sourced by the Baud Rate Generator output; /TRxC's 
output is from the BRG. The input to the BRG is from the / 
RTxC. 

The BRG's time constant is loaded in WR13 and WR12 so 
that the /RTxC's 3.6864 MHz signal is divided by 16 in 
order to obtain a 230.4 kHz signal for the transmitter clock. 
WR14 makes certain that the DPLL is disabled before 
choosing the clock source and operating mode. The DPLL 
is enabled by issuing the Enter Search Mode in WR14. 



TRANSMITTING A LLAP FRAME 

Listing 2 shows the assembler code for subroutine txenq, 
which sends an lapENQ frame on the line once the system 
has determined that the line is quiet. Note that this routine 
can easily be generalized to send any frame. 

The first responsibility of txenq is to send the sync pulse 
required by the CSMA/CA protocol. To do this, txenq sets 
the /RTS pin active low, enabling the transmitter drivers, 
and then sets it high again to disable them. In order to 
satisfy the requirements of the CSMA/CA protocol, the 
transmitter drivers must remain off for at least one bit time 
(4.3 usee) to guarantee that all the receivers see at least 
one transition. Our routine satisfies this requirement 
because the two Id instructions (7 T states each), the two 
nop instructions (4 T states each) and the two "out" 
instructions (11 T states each) required to set the /RTS line 
high, take more than 4.3 |isec to execute on the 10 MHz 
Z801 81 . The transmitter drivers must then remain off for at 
least two bit times in order to ensure that all receivers lose 
clock; again, the routine depends upon the time required 
to execute the instructions before we turn the transmitter 
drivers on again. 



After sending the sync pulse and waiting the required 
period of silence, txenq turns on the transmitter drivers to 
send the frame. Now, the routine must wait while the SCC 
sends out the leading flags. This takes 16 bit times, and 
since the SCC does not tell when this has happened, the 
transmit routine has no choice but to time this. Our routine 
does this by calling bittime, which is discussed below. 

When the two flags have been transmitted, the first data 
byte is written to the data register of the SCC. Thereafter, 
. the routine polls the SCC status register, and when that 
register shows the transmit buffer register is empty, the 
routine sends the next data character. This polling method 
can obviously be replaced by an interrupt routine that is 
entered when the transmit buffer is empty or by setting up 
the Z80181's DMA to send characters on demand to the 
SCC. 

After the first data byte is transmitted, the txenq routine sets 
the SCC to mark on idle so that the abort is sent when the 
frame is over. This operation can be done any time after the 
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first data character has been placed in the transmit buffer 
and before the trailing flag is shifted out. Txenq asserts this 
mark on idle command after the first character is placed in 
the transmit buffer so that LLAP has control and that no 
issues of latency may arise (particularly in designs using 
interrupt or DMA). 

After the last data byte is written to the SCC, the transmit 
routine must wait while the last data byte (the one that the 
SCC had just sent to shifter), the two CRC bytes, one flag 
byte and 1 2 to 1 8 bit times of marking are transmitted. This 
total of 44 to 50 bit times is again timed by bittime. When 
bittime indicates that enough time has elapsed, the 
transmitter drivers are turned off. 

Since our hardware includes connecting the output of the 
baud rate generator to the input of counter/timer 1 on the 
Z80181, that counter timer counts the bit times. 



The bittime routine feeds an appropriate count value into 
the counter and enables an interrupt routine to receive 
control when the count expires. The interrupt routine 
etc lint, shown in Listing 4, sets the timeflag which the 
transmit routine polls. 

Note that the call to bittime, the interrupt routine, the 
polling code and the length of time it takes to write to the 
SCC registers after a polling loop is exited, all take up a 
time that can be a significant number of bits. In order to do 
these timings accurately, calculate the number of PCLK 
cycles required to execute these pieces of code and to 
adjust the counter value that bittime requires. This 
adjustment is dependent on the hardware configuration 
and on the exact implementation details of the code. 

Note, incidentally, that software must put the entire frame 
into the transmit register, including the addresses. The 
SCC does not generate addresses even when set in WR6. 



RECEIVING LLAP FRAMES 

In the experiments, the interrupt routines were used to 
receive characters and to handle special conditions when 
the frame is complete. Listing 3 shows the interrupt handlers 
that are entered when the SCC receives a character and 
when the SCC interrupts for a special condition (typically, 
end of frame). As with transmission, it is obvious that we 
could receive characters by polling the SCC (using up all 
available CPU cycles) or by using DMA (using up very 
few). It is estimated that the recint routine uses up about 
1/3 of the available 34 |isec (4.3 jisec x 8-bit times) cycles 
on a 10 MHz processor. 

The recint routine moves each character as it is received 
from the SCC to a memory buffer and increments the buffer 
pointer. The frame's data length is checked to make 
certain that the maximum allowable frame size is not 
exceeded. 

The spcond interrupt handler checks the status of the SCC 
to find out what has happened. The presence on an 
overrun condition or a CRC error is flagged as a receive 
frame error. 



The spcond routine decrements the receiver buffer address 
by two to account for the two CRC bytes that are read from 
the SCC before the special condition interrupt occurs. 
Note that the SCC does not filter these CRC bytes, nor does 
it filter the address byte. Everything received after the 
leading flags and before the trailing flags appears in the 
receive buffer. 

One difficulty that arises in LLAP that was not addressed 
here is that the receipt of a frame very often creates an 
obligation to send a frame back to the sender within the 
interframe gap, which is 200 psecs. This difficulty is even 
greater than it might appear. The 200 ^isec gap starts when 
the frame is received; it ends when- the leading flags and 
destination address of the response are sent. Start 
sending the response soon enough to allow sending two 
leading flags (plus a possible leading flag fragment) and 
the first data character, and to allow for the 3-bit delay in the 
SCC shifter. Therefore, start sending early enough to 
transmit 35 bits before the interframe gap expires, or about 
70 usees after you receive the frame. 
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CONCLUSIONS 



The problems of sending the sync pulses, the timing of 
transmission packets, and the problems associated with 
the reception of packets as defined by LLAP are handled 
bytheZ80181 and its peripherals. Itwas demonstrated that 
LLAP frames can be transmitted and received by using the 
straight forward polling method and by using interrupt 
routines. In a much busier environment where the 
processor cannot strictly be an LLAP engine, other methods 



such as using DMA in a fully interrupt driven environment 
must be used. It was also demonstrated that severe CPU 
overhead is used in setting up the sync pulses, timing out 
delays, etc., before each LLAP frame. A modified SCC that 
transmits and receives special LLAP frames helps in off 
loading some of this overhead hence freeing the CPU to 
do other tasks. 



7-134 



APPENDIX A 
Listing 1 - Assembler Code for SCC Initialization 
LISTING 1 





475 






.********^*************************** 




476 






;subroutine to initialize sec registers 




477 






.*******;******************************* 


000001 e2 


478 initscc: 








000001e2 f3 


479 


di 




;disable int while programming sec 


000001 e3f 5 


480 


push 


af 




000001e4 c5 


481 


push 


be 




00000165 65 


482 


push 


hi 






483 








00000166 3e09 


484 


Id 


a,09h 


;WR9 


000001 e8 d3e8 


485 


out 


(scc_cont),a 


; point to sec register 


00000 1ea 3e80 


486 


Id 


a,80h 


;channel reset 


000001 ec d3e8 


487 


out 


(scc_cont),a 


;scc register value 


000001 ee 00 


488 


nop 




;delay needed after sec reset 




489 










490 








000001 ef 21 Wwww 


491 


Id 


resectable 


;fetch start of sec init table 


000001 f2 


492 scd: 








000001f2 7e 


493 


Id 


a,(hl) 


;fetch register pointer value 


000001 f3 feff 


494 


cp 


Offh 




000001 f5 caWwww 


495 


jp 


z.finscc 


;if reg a =0ffh then initscc finished 


000001 f8 d3e8 


496 


out 


(scc_cont),a 




000001 fa 23 


497 


inc 


hi 




000001fb 7e 


498 


Id 


a.(hl) 




000001fc d3e8 


499 


out 


(scc_cont),a 




000001fe 23 


500 


inc 


hi 




000001ff c3R000+01f2, 


501 


jp 


scd 


;loop back 




502 








00000202 


503 scctable: 








00000202 04 


504 


db 


04h 


;WR4 


00000203 20 


505 


db 


00100000b 


;sdlc uses Ix.sdlc mode.no parity 




506 








00000204 01 


507 


db 


01h 


;WR1 


00000205 00 


508 


db 


OOh 


;nothing,rx,tx and ext int disabled 




509 








00000206 02 


510 


db 


02h 


;WR2 


00000207 00 


511 


db 


OOh 


;vector base is OOh 




512 








00000208 03 


513 


db 


03h 


;WR3 


00000209 cc 


514 


db 


Occh 


;rx 8b/char,rx ere enabled.address 




515 






;search mode for adlc address filtering 




516 






;rx disabled. 




517 








0000020a 05 


518 


db 


05h 


;WR5 


0000020b 60 


519 


db 


60h 


;tx 8b/char, set rts to disable drivers 




520 








0000020c 06 


521 


db 


06h 


;WR6 


0000020d 00 


522 


db 


OOh 


;address field='myaddress' in main pgm 




523 








0000020e 07 


524 


db 


07h 


;WR7 


0000020f 7e 


525 


db 


7eh 


;flag pattern 




526 








00000210 09 


527 


db 


09h 


;WR9 


00000211 01 


528 


db 


01h 


;stat low, vis therefore vector returned 




529 






;is a variable depending on the source 




530 






;of the interrupt. 
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531 






00000212 oa 


532 


OD 


oan 


00000213 60 


533 


db 


OeOh 




534 






00000214 0b 


535 


db 


Obn 


00000215 To 


536 


db 


0f6h 




537 






00000216 0C 


538 


/•IK 

db 


oen 


00000217 06 


539 


db 


Obn 




540 






00000218 Ou 


541 


<~IK 


Odn 


00000219 00 


542 


db 


OOh 




543 






0000021a Oe 


544 


db 


Oeh 


0000021D 60 


545 


db 


60h 




546 








547 






0000021c Oe 


548 


db 


Oeh 


0000021a cO 


549 


db 


OcOh 




550 








551 






00000216 06 


552 


*«IK 

db 


n«K 

oen 


000002 1T a0 


553 


db 


OaOh 




554 








555 






00000220 oe 


556 


db 


r\«K 

oen 


00000221 20 


557 


db 


2on 




ceo 
ooo 








559 






00000222 0e 


560 


db 


n«K 

oen 


00000223 01 


561 


db 


AH K 

oi n 




562 






00000224 03 


563 


db 


ojn 


00000225 CC 


oo4 


/-IK 

db 


Occh 




565 






00000226 Ot 


566 


/-IK 

db 


otn 


00000227 00 


567 


db 


OOh 




568 








569 






00000228 10 


570 


db 


10h 


00000229 10 


571 


db 


ion 




572 






0000022a 01 


573 


db 


0lh 


0000022b 00 


574 


db 


00h 




575 






0000022c 09 


576 


db 


09h 


0000022a 09 


577 


db 


uyn 


0000022e TT 


DfO 


db 


unn 




579 






0000022T 


580 finscc: 






0000022T ei 


COM 

ool 


pop 


kl 

ni 


00000230 d 


582 


pop 


be 


00000231 f1 


583 


pop 


af 


00000232 c9 


584 


ret 






585 







;WR10 

;crc preset to one.fmO, flag idle/undr 
;WR11 

;rtxc=xtal,rxc=dpll,txc=brg,trxc=brg out 
;WR12 

;brg tc low.for 230.4kbps using rtxc=3.68MHz 

;WR13 
;brg tc high 

;WR14 
;disabledpll 

;no local loop back.brg source=rtxc 
;WR14 

;select fm mode 

;no local loop back.brg source=rtxc 
;WR14 

;dpll source=rtxc, 

;no local loop back.brg source=rtxc 
;WR14 

;enter search mode 
;no local loopback 

;WR14 

;null,no local loopback.enable the brg 
;WR3 

;rx 8b/c,enable rx crc.addrs src.rx disable 
;WR15 

;ext/stat not used 
;WR0 

; reset ext/stat once 
; reset ext/stat twice 

;WR1 

•.disable all int sources 

;WR9 
•.enable int 
•.finished 
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LISTING 2 





600 










601 






;Subroutine to transmit the llapenq packet 




602 






***************************************** 


00000244 


603 txenq: 










604 








00000244 to 


605 


push 


af 


;save status and a reg 


00000245 Co 


606 


push 


be 


;save 


00000246 e5 


607 


push 


hi 


;save 




608 






; 


00000247 To 


609 


di 




;make sure that 




610 






;no interrupt routine 




611 






;nor should interrupt 




612 






;occur during 




613 






;this subroutine. 


00000248 3e03 


614 


Id 


a,03h 




0000024a d3e8 


615 


out 


(scc_cont),a 


;WR3 


0000024c 3ecc 


616 


Id 


a.Occh 




0000024e d3e8 


617 


out 


(scc_cont),a 


;8b/char,rx crc 




618 






;enable,addrs sre 




619 






;and rx disabled 




620 








00000250 3e0a 


621 


Id 


a.Oah 


;select WR10 


00000252 d3e8 


622 


out 


(scc_cont),a 




00000254 3ee0 


623 


Id 


a,1 1100000b 


;idle with flags 


00000256 d3e8 


624 


out 


(scc_cont),a 






625 










626 






;****enable transmitter ***** 


00000258 3e05 


627 


Id 


a,05h 


;select WR5 


0000025a d3e8 


628 


out 


(scc_cont),a 




0000025c 3e68 


629 


Id 


a,01 101000b 


;enable tx 


0000025e d3e8 


630 


out 


(scc_cont),a 






631 






• 




632 










633 






;****enable rs-422 driver 


00000260 3e05 


634 


Id 


a,05h 


;select WR5 


00000262 d3e8 


635 


out 


(scc_cont),a 




00000264 3e6a 


636 


Id 


a,01 101010b 


;enable tx, 


00000266 d3e8 


637 


out 


(scc__cont),a 


;resetrts 


00000268 00 


638 




nop 




00000269 00 


639 




nop 






640 






;nop's needed to complete 4.3 usee 




641 






;for 1 bit time enable of transmitter. 




642 






;total delay=2 (7+1 1 +4) T states at 10 MHZ 




643 










644 






;****disable rs-422 driver for 2 bit times***** 


0000026a 3e05 


645 


Id 


a,05h 


;select WR5 


0000026c d3e8 


646 


out 


(scc_cont),a 




0000026e 3e68 


647 


Id 


a,01 101000b 


;enable tx, set rts 


00000270 d3eo 


648 


out 


(scc_cont),a 






o4y 






• 


00000272 3e80 


650 


Id 


a, 10000000b 


; reset txerc 


00000274 d3e8 


651 


out 


(scc_cont),a 




00000276 0601 


652 


Id 


b,01h 


;delay count 


OOUUO^/o 


653 csloop: 








00000278 10fe 


654 


djnz 


csloop 


;loop needed 




655 






;to complete 




656 






;8.6 usee min. 




657 






;or 2 bit times. 




658 






;****enable rs-422 driver for llap transmission 


0000027a 3e05 


659 


Id 


a,05h 


.•select WR5 
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0000027c d3e8 
00000276 3e6b 



00000280 d3e8 



00000282 0e08 
00000284 cdWwww 



00000287682 16: 
00000287 3aWwww 
0000028a cb4f 

0000028c 28f9 
00000286 cb8f 
00000290 32Wwww 

00000293 3e03 
00000295 d3e5 



00000297 0602 
00000299 21Wwww 

0000029c 7e 
0000029d d3e9 
0000029f 23 

000002a0 3ec0 
000002a2 d3e8 

000002a4 f3 
000002a5 3e0a 
000002a7 d3e8 



000002a9 3ee8 
000002ab d3e8 

000002ad 3e00 
000002af d3e8 
000002b1 dbe8 
000002b3cb57 
000002b5 28f6 
000002b7717txq1: 
000002b7 7e 
000002b8 d3e9 
000002ba 23 



660 
661 
662 
663 
664 
665 
666 
667 
668 
669 
670 
671 
672 
673 
674 
675 
676 
677 
678 
679 
680 
681 

683 
684 
685 
686 
687 
688 
689 
690 
691 
692 
693 
694 
695 
696 
697 
698 
699 
700 
701 
702 
703 
704 
705 
706 
707 
708 
709 
710 
711 

712txq2: 

713 

714 

715 

716 

718 
719 
720 
721 



out 
Id 



out 



(scc_cont),a 
a,01101011b 



(scc_cont),a 



Id 
call 



Id 
bit 

jr 

res 
Id 

Id 
out 



Id 
Id 

Id 

out 

inc 

Id 
out 

di 
Id 
out 



Id 
out 

Id 

out 

in 

bit 

jr 

Id 

out 

inc 



c,08h 
bittime 



a,(timflg) 
1,a 

z,l6 
1,a 

(timflg).a 
a,03h 

(ctc1_cont),a 



b,02h 
hl.txlapenq 

a.(hl) 

(scc_data),a 
hi 

a.OcOh 
(scc_cont),a 



a.Oah 

(scc_cont),a 



a,1 1101000b 
(scc_cont),a 

a.OOh 

(scc_cont),a 
a,(scc_cont) 
2,a 
z,txq2 

a,(hl) 

(scc_data),a 
hi 



;sdlc crc, 
;txcrc enable, 
; reset rts 



'start counting out 2 flag character times *' 

;count 16 bit times 
from the rs-422 enable 
for 2 flags. 

btdelay=subr delay+ctd int+polling=8bits 
16 bit times-btdelay=16-8=08h 



bittime delay 
is stored in reg.c 
and bit1 of timflg 
will indicate 
count termination. 

itimer flag 

bit1=1 then 
;count terminated 

reset timflg bit1 
update timflg 



disable int, 
software reset 
to kill the counterl 
2+1 bytes to transmitted 
point to txlapenq buffer 
send 1st byte 

;and send it 

point to the next byte 

reset eom latch command 



disable all int 
select WR10 

idle with 1's 

at the end of the frame 



;rrO 

;read rrO 
;read tx buffer empty 
;loopifzero 



and send it 

point to the next byte 
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nnnnnohh into 

UUUUUdOD IUIU 


799 


djnz 


tvnO 


iloop until all 




100. 






l bytes have been 




10 A 
f C.H 






•tronemlHarl 
(Uctllol IIIUcU. 




795 
1 C.D 










726 








nnnnn9hH 9o9ft 

UUUUU^UU Oo£0 


101 

1 C.I 


IH 
IU 


a H9flh 


,16001 la irit panuiiiy 


nnnnn^hf HQoft 

UUUUUHUI UOoO 


ion. 


out 








729 






'nnto'tY hi iff or 




1 ou 






•omntx/ hannanc ac tv 
(Wllipiy llap|Jailo do La 




731 






'chiftor ic IraHoH 
,olllllol lo IUcLUoU. 




/ Oc 










7QQ 
1 OO 






;count= last byte+ 




/ 04 






,UrCTTIagT I^UIl III 1 loo-UlUolay 




795 






,UlUolay— bUUI UOIctyTOlO 1 II ll+pUlllliy— OUIlb 




79fi 
/ OO 






,Ot IOtOt 1 CrO— OO— t*tll 


UUUUU^C I U6c4 


797 
/Of 




r> OAV\ 
C,(£:4n 




uuuuu^oo ouvvwww 


/ OO 


rail 


UlUllllo 


(Ulllllllo Uolay 




79Q 

/ Ov7 






,io biuiou in loy.vj 




7,40 

/ 4 U 








nnnnn9rR74i I7« 








,1111101 iidy 


nnnnnppfi SaWwww 

tJVJVJVJlJ£.OU vjaVVWVVW 


742 


Id 


^timfln^ 
d ( \ 111 1 niyy 




nnnnnPrQ phdf 


7.49 
f 40 


hit 


I ,o 


• if Kit1— 1 thon pni inf flnlch 
(IIUIll— I llloll OUUilL lllllbll 


nnnnn9rh 9QfQ 

UUUUU^CD £Oiy 


l 44 


jr 


■7 17 




nnnnn9r»H phftf 

UUUUU^OU OUOI 


7.45 


T6S 


1 a 
1 ,a 


,ioboi Liriiiiy uii i 


UUuUU£CT o^VVWWW 


1AR 
IHO 


IH 

la 


(iimiigj,a 


;update timflg 




1A1 
1 Hi 






• 


UUUUUilCI^ OoUO 


1AR 
f HO 


IH 
IU 


a.uon 






1 H& 


out 


f*rtri rrntN a 


•Hicahlo int crsihkiora rocat 
,UlbdUlo II ll,bUILWdlo lobol 




750 
1 OU 






,IU MM OUUlHol 




751 






.**** r j: cja u.| fi r ~Aoo r\r\\iar flftpr 19 tn 1ft 1'q*' 

, UlbdUlO lb H£.C UII Vol dllol \C\\J IO lb 


nnnnn9HR 9«nR 

UUUUUtUD OqUJ 


759 


IH 

IU 


a Pi5h 


,boioUL vvno 


nnnnn9Hft H9«r 

UUUUU<lUO UOBO 


759 
I OO 


out 






nnnnn9Ha ^«fin 


754 

1 OH 


IH 

IU 


a oi mnnnnh 

a,VJ I IUUUUUU 


'HicaHIo tY cot rtc 
,UlbdUlo La, bo l lib 


nnnnn9Hr HQoft 


755 
f OO 


out 








75fi 
« 00 








UUUUU^Uo oouo 


757 
IDI 


IH 
IU 


a,UOi 1 




nnnnnoon HQoft 
uuuuu^eu uoeo 


IRQ. 
1 OO 


out 


vSCC_COni; l a 


,VVno 


000002e2 3ecd 


759 


Id 


a.Ocdh 




UUuUU£e4 Q080 


7cn 
/ ou 


out 


(scc_cont),a 


,oD/cnar,rx crc enauieu, 




7fi1 






(dUUioSS bodiCll dllU IX olldUloU 




7R9 










763 






.************************************* 
• 




I KiH 










7fi5 
/ OO 






•poimt fnr tho intorframo nan 
,uUUIll iui ll lo ll llol lldl l io ydp 




1RR 
f OO 






,oi «iuu usee or 40 dii nmes. 




7R7 
/Of 






,Diaeiay=suDr aeiay+cic iini+poiiing^oDiis 




7fift 
1 OO 






_ htHolaw— AR-R— 9Rh 
,40 - ULUoldy— 40-0—^011 




7fiQ 

f 057 






• nrvta that timfln \A/ill Ko nnlloH in 
,IIUlo llldl llillliy Will Uo |JUIIoU III 




770 
1 IU 






,lllo iTlain lUUUIIO. 




111 
1 1 I 








000002e6 0e26 


772 


Id 


c,26h 




0000090ft pHVAAaaaaa/ 
uuuuuiioo uuvvwww 


779 
r / 


rail 
Call 


UlUllllo 






774 

1 1 H 










775 
# / 






•hittimo Hola\/ ic ctnroH in ron p 
,uiiiiiiio uoidy ib biuiou hi loy.u 




77R 
f /O 






.************************************* 


UUUUU^eU I 


111 

III 


pop 


hi 

111 


,IOblUlO 


uuuuu^ec c 1 


77ft 
1 IO 


pop DC 




,resiore 


0000090H f 1 
uuuuu^ea n 


77Q 
f f y 


pop 


af 


• roptA ro ©fail io nnrj Q rori 

jloblOlo SlalUb allU d Toy 


000002ee c9 


780 


ret 








781 










782 










783 
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784 






•qi ihrni itinp to timp ni it hit timp A *3 i iqpp nor hit 

,OULfl VJUlll IO IAJ III 1 IO UUl Ull III IIC TO USCl/ LJCI Ull 




785 






•rpniQtpr p pnntflinQ thp niimhpr nf hitQ tn hp 

)l CyloLCI Uvl IICIII IO 11 IC 1 IUI 1 IL/CI VJ 1 L/llO IVJ uc 




7ftfi 






pni intpH Hnwn 

UUUIILCU UUWI 1 


nnnnnppf 


f OD 

787 hittimp* 

/Of Ullill 1 ItJ. 










788 


push 


af 


•cawp ctflti iq unci s rpn 
,oavc oiaiuo cii i\j ci i cy 


nnnnnpfn 


789 


push 


be 


'save 


nnnnopfi p^ 


790 


push 


hi 


.save 




791 








nnnnnpfp 9pHP 


792 


Id 


a 0d2h 


•ptpl int \/pptnr 

I Mil VtJUlUI 


000002f4 d3e5 


793 


out 


(ctd cont),a 






794 








nnnnnpfR ^Pdf 


795 


id 


a 11011111b 

CL j 1 1 \J 1 1 1 1 IU 






796 


out 


^ptp"l prints p 

\ Is lis l_OUI ll/|Cl 


■pnsihlp int 

,d ICIUIC/ II II 




797 






•oplppt pnnntpr mnrlp 




798 






•plk/trn pHnp ^tarta with rtainn pHn 
,oir\/iiy cvjy oicii 10 vvmi iioiiiv^ cvjy 




799 






•timp pnn^tant follows 

t LI f I lu wVJI IOIGI 11 IVsllUVVO 




800 






'^nftwarp rp<?pt 




801 


Id 


a c 


•rpn p. pnntflin*? thp nurnhpr nf hit<? 

|lv7M v wUI 1 I Gil 1 I O LI IU 1 IUI 1 Ik^Wl \Jl Im/IIO 


000002fb d3e5 


802 


out 


fctd cont^ a 


"load the number of bits to be counted 




803 






.** 


nnnnnpfn pi 


804 


nnn 
pup 


hi 


t l COLV-'I C 


000002fe c1 


805 


pop 


be 


; restore 


000002ff f 1 


806 


pop 


af 


; restate status and a reg 


00000300 f b 


807 


ei 






00000301 c9 


808 


ret 








809 
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LISTING 3 





1131 










1132 
1133 






;receive int service routine. 




1134 






;save received character in receiver buffer 










pointed 




1135 






;to by rxpointer 




1136 








0000044d 


1137recint: 








0000044d f5 


1138 


push 


af 


;save af 


0000044e d5 


1139 


push 


de 




0000044f e5 


1140 


push 


hi 




00000450 dbe9 


1141 


in 


a,(scc_data) 


;read sec data 


00000452 2aWwww 


1142 


Id 


hl.(rxpointer) 




00000455 77 


1143 


Id 


(hl).a 


;save it 


00000456 23 


1144 


inc 


hi 


;update pointer 


00000457 22Www 


1145 


Id 


(rxpointer).hl 




0000045a ed5bWwww 


1146 


Id 


de.(rxbufend) 


;end of rx buffer 


0000045e af 


1147 


xor 


a 


; reset cy 


0000045f ed52 


1148 


sbc 


hl.de 




00000461 c2Wwww 


1149 


jP 


nz.recexit 


;if not zero.then receive 










byte length is ok 


00000464 21Wwww 


1150 


Id 


hl.recerrflg 




00000467 cbc6 


1151 


set 


0,(hl) 


;set bit0=1 maxfrmflg to indicate error 




1152 






; because of max frame 










size exceeded. 


00000469 


1153recexit: 








00000469 3e38 


1154 


Id 


a,038h 




0000046b d3e8 


1155 


out 


(scc_cont),a 


;reset highest ius 


0000046d e1 


1156 


pop 


hi 




0000046e d1 


1157 


pop 


de 




0000046f f 1 


1158 


pop 


af 


; restore af 


00000470 f b 


1159 


ei 




;enable int 


00000471 c9 


1160 


ret 




; return from int 




1161 






;note ret and not reti is used for sec 




1162 






interrupts on the z80181 . 




1163 










1164 
1165 
1166 






;special receive interrupt service routine 




1167; 






"parity is special condition" bit is off. 




1168; 






special conditions are eof or rx overrun error. 




1169; 






ere error flag is valid only if eof is valid. 




1170; 






if frame is ok then recerrflg bit1 =0, otherwise 










bit1=1. 




1171 








00000472 


1172 spcond: 






00000472 f5 


1173 


push 


af 


;save af reg 


00000473 c5 


1174 


push 


be 


; 


00000474 e5 


1175 


push 


hi; 






1176 








00000475 3e01 


1177 


Id 


a,01h 




00000477 d3e8 


1178 


out 


(scc_cont),a 


;read rr1 


oouuu47y a Deo 


1179 


in 


a,(scc_cont) 




0000047b e660 


1180 


and 


01100000b 


;check bit6 (ere) or bit5 (overrun) 


0000047d caWwww 


1181 


jp 


z.ok 






1182 








00000480 21Wwww 


1183 


id 


hl.recerrflg 


;fetch receive error flag 


00000483 cbce 


1184 


set 


1,(hl) 


;set bit1 =1 for frame not ok 


00000485 c3Wwww 


1185 


jP 


crc_exit 
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nnnnriiiftft 

uuuuutoo 


1 iftfi 
1 100 


Ul\. 






uuuuutoo C 1 vvwww 


1187 


Id 


1 11,1 WUUl 1 iiy 


,iuioii loooivo oirur Tidy 


0000048b cb8 


1188 


res 


1 (hO 


;set bit1 =0 for frame ok 




1189 










1190 








0000048d 


1191 crc_exit: 






OOnClCiARri HhpQ 

UUUUUHOU UUOC7 




in 




;read 2nd crc (debug only) and 










scrap 


UUUUUHOI caVVWWW 


i iyo 


i a 


ni,^rApoiriier/ 


,ioaa pointer 




i jy^ 


doc 


hi 
III 


,aujusi rx dutt pir ior crci 


UUUUUH90 £u 


i iyo 


d8C 


hi 
Ml 


iadjust rx buff ptr for crc2 


uuuuutv7*T ttvyvyyvw 


1196 


Id 


^1 AfJUII Hot /,III 




1197 










1198 spexit: 








UUUUUH9 / OOOO 


1199 


Id 


d,UOOll 






1200 


out 




,10061 nigriosi ius 




1201 








0000049b e1 


1202 


pop 


hi 


•restore hi 


0000049c d 


1203 


pop 


be 


; restore be 


0000049d f 1 


1204 


pop 


af 


; restore af 


0000049e f b 


1205 


ei 




;enable int 


0000049f c9 


1206 


ret 




;return from int 




1207 
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LISTING 4 





loUo 






**************************************** 




1307 
1308 






ctd timer int handler 




1309 






**************************************** 


00000509 


1310 ctdint: 










1311 






ctd is programmed in counter mode. 




1312 






external trigger edges is provided by 




1313 






/trxc pin at intervals of 4.3 usee. 




1314 






bit1 of timflg is set when count is terminated. 


00000509 f5 


1315 


push 


af 




ooooooOa co 


1316 


push 


be 




0000050b e5 


1317 


push 


hi 






1318 






** update the timing flag ** 


0000050c 21Wwww 


1319 


Id 


hl.timflg 




0000050T 7e 


1320 


Id 


a,(hl) 


get recent timflg 


00000510 cbcf 


1321 


set 


1,a 


bit1 =1 after count is over 


00000512 77 


1322 


Id 


(hl),a 


update the timflg 


00000513 e1 


1323 


pop 


hi 




00000514 d 


1324 


pop 


be 




00000515 T1 


1325 


pop 


af 




00000516 fb 


1326 


ei 






r\r\r\r\r\E A"? — I >i — I 

00000517 ed4d 


1327 


reti 








1328 










1329 










1330 










1331 






********************************** 




1332 






interrupt vector table for the sec 




1333 






********************************** 




1334 






the status of the interrupt source will affect 




1335 






the interrupt vector. The interrupt handler's 




1336 






address are set in a block, as below. 


OOOOOaOO 


1337 


org 


sdlc + OaOOh 




OOOOOaOO 


1338 sccvect: 










1339 


if 


scc_a 




OOOOOaOO 


1340 


.block 


8 


reserve vector for other ch 




1341 


endif 






00000a08 R000+03e9, 


1342 


dw 


txint 


tx int 


OOOOOaOa R000+04c8, 


1343 


dw 


ext_stat 


ext/stat int 


OOOOOaOc R000+0433, 


1344 


dw 


recint 


rx char int 


OOOOOaOe R000+0454, 


1345 


dw 


spcond 


sp rec cond int 




1346 










1347 


if 


not scc_a 




00000a10 


1348 


.block 


8 


reserve vector for other ch 




1349 


endif 








1350 








OOOOOalo 


1351 temp: 


.block 


1 






1352 










1353 










1354 






********************************** 




1355 






interrupt vector table for the etc 




1356 






********************************** 


OOOOOadO 


1357 


org 


OadOh 




OOOOOadO R000+04d8, 


1358 


dw 


ctcOint 


reserved for ctcO int routine 


00000ad2 


1359 


org 


0ad2h 




00000ad2 R000+0509, 


1360 


dw 


ctdint 


reserved for ctd int routine 




1361 










1362 






************************ 




1363 






receive buffer area 




1364 






************************ 
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00001000 
00001000 



OOOObOOO 



0000b258 ff 
0000b259 
0000b25a 81 



1365 


org 


1366 rx_DUTt: 


.block 


1367 




■i OQQ 




1389 




1390 




1391 




1392 


org 


loao 




loyy 




1400 




1401 




1402 txlapenq: 


db 


1 403 myaddress 


.block 


1404 


db 


1405 





1000h 
length 



ObOOOh 



Offh 
1 

81h 



************************ 

transmitter buffer area 
************************ 



**********************: 

[transmit Hap enq packet (3bytes) 
******************************** 

broadcast id 
guess at myaddress 
Hap enq type 
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APPENDIX B 



( State/Timing E ) ( Haveform 1 ] 



(cancel ) ( Run ) 



C 



Accumul ate 
Off 



Sample period ■ 800.00 ns 



(s/Div ] i Delay ) ( 
20.0 us J [-38.93 us J ^ 



Markers 
Off 



/m 

/IORQ 

/INTO 
/RTS 
TXD 
/TXRC 


i \ 




i Mill Ml 


y 


UUWWUL 


mm 

MJUM 


UUU1L 

nnnnnnnn 


innnnnnnniMinnnnrinn 












CRC2 




0111 1110 




18 rs 



Flag 



12 to 18 Vs at the end of an LLAP frame 
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APPENDIX B (CONTINUED) 



( State/Timing ( Waveform 1 ] 



(cancel ) ( 



Accumul ate 
On 



Sample period = 2.0000 us 



(s/Div 1 ( Delay 1 f 
20,0 us J [ 27.27 usj ^ 



Markers 
Off 



/Ml 

/IORQ 

/MREQ 

/INTO 

/RTS 

TXD 

/TXRC 



^n^¥n ir 



t — r - 
i i 
I I 



1 1 n i n i rm nmiimuimnmiHTiniiniiiiiiimnmiiiiiiii nn mini 

I I I I I I II I I I I I I I I I I I I I I I I I I I I I I I I I I I I 1 1 M I I I I I I I I I II I I I I I I I I 1 1 I I I I I I I I II I I I I I I I I II I I I I I I I I I 

LU LU LU 1 1 LLU I LLLI I LLLLI I U U I LULJ MJ LUJ LLLLLLLU I U U I L 



LJ 



MlllUWUllilMllimilMlIlIl 



CSMA/CA 
pulse 



01111110 
Flag 



01111110 
Flag 



Flag 



CSMA/CA before an LLAP frame 
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APPENDIX B (CONTINUED) 



f State/Timing i^) ( Haveform 1 ] 



^Cancel ] ( 




LLAP frame with CSMA/CA 



An LLAP Frame 



7-147 



7-148 



On-Chip Oscillator Design 



DESIGN AND BUILD RELIABLE, COST-EFFECTIVE,ON-CHIP OSCILLATOR CIRCUITS THAT 
ARE TROUBLE FREE. PUTTING OSCILLATOR THEORY INTO A PRACTICAL DESIGN 
MAKES FOR A MORE DEPENDABLE CHIP. 



INTRODUCTION 

This Application Note (App Note) is written for designers 
using Zilog Integrated Circuits with on-chip oscillators; 
circuits inwhichthe amplifier portion of afeedbackoscillator 
is contained on the IC. This App Note covers common 
theory of oscillators, and requirements of the circuitry (both 
internal and external to the IC) which comes from the 
theory for crystal and ceramic resonator based circuits. 

Purpose and Benefits 

The purposes and benefits of this App Note include: 

1 . Providing designers with greater understanding of how 
oscillators work and how to design them to avoid 
problems. 



2. To eliminate field failures and other complications result- 
ing from an unawareness of critical on-chip oscillator 
design constraints and requirements. 

Problem Background 

Inadequate understanding of the theory and practice of 
oscillator circuit design, especially concerning oscillator 
startup, has resulted in an unreliable design and subse- 
quent field problems (See on page 10 for reference mate- 
rials and acknowledgements). 



OSCILLATOR THEORY OF OPERATION 



The circuit under discussion is called the Pierce Oscillator 
(Figures 1 , 2). The configuration used is in all Zilog on-chip 
oscillators. Advantages of this circuit are low power con- 
sumption, low cost, large output signal, low power level in 



the crystal, stability with respect to V cc and temperature, 
and low impedances (not disturbed by stray effects). One 
drawback is the need for high gain in the amplifier to 
compensate for feedback path losses. 



v i h — v , 

A^O 



Figure 1. Basic Circuit and Loop Gain 




Figure 2. Zilog Pierce Oscillator 
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OSCILLATOR THEORY OF OPERATION (Continued) 



Pierce Oscillator (Feedback Type) 

The basic circuit and loop gain is shown in Figure 1 . The 
concept is straightforward; gain of the amplifier is 
A = Vo/Vi. The gain of the passive feedback element is 
B = Vi/Vo. Combining these equations gives the equality 
AB = 1 . Therefore, the total gain around the loop is unity. 
Also, since the gain factors A and B are complex numbers, 
they have phase characteristics. It is clear that the total 
phase shift around the loop is forced to zero (i.e., 360 
degrees), since V |N must be in phase with itself. In this 
circuit, the amplifier ideally provides 1 80 degrees of phase 
shift (since it is an inverter). Hence, the feedback element 
is forced to provide the other 180 degrees of phase shift. 

Additionally, these gain and phase characteristics of both 
the amplifier and the feedback element vary with fre- 
quency. Thus, the above relationships must apply at the 
frequency of interest. Also, in this circuit the amplifier is an 
active element and the feedback element is passive. Thus, 
by definition, the gain of the amplif ier at frequency must be 
greater than unity, if the loop gain is to be unity. 

The described oscillator amplifies its own noise at startup 
until it settles at the frequency which satisfies the gain/ 
phase requirement AB = 1 . This means loop gain equals 
one, and loop phase equals zero (360 degrees). To do this, 



the loop gain at points around the frequency of oscillation 
must be greater than one. This achieves an average loop 
gain of one at the operating frequency. 

The amplifier portion of the oscillator provides gain > 1 plus 
1 80 degrees of phase shift. The feedback element provides 
the additional 180 degrees of phase shift without attenu- 
ating the loop gain to < 1 . To do this the feedback element 
is inductive, i.e., it must have a positive reactance at the 
frequency of operation . The feedback elements discussed 
are quartz crystals and ceramic resonators. 

Quartz Crystals 

A quartz crystal is a piezoelectric device; one which 
transforms electrical energy to mechanical energy and 
vice versa. The transformation occurs at the resonant 
frequency of the crystal. This happens when the applied 
AC electric field is sympathetic in frequency with the 
mechanical resonance of the slice of quartz. Since this 
characteristic can be made very accurate, quartz crystals 
are normally used where frequency stability is critical. 
Typical frequency tolerance is .005 to 0.3%. 

The advantage of a quartz crystal in this application is its 
wide range of positive reactance values (i.e., it looks 
inductive) over a narrow range of frequencies (Figure 3). 




" fs - fp is very small (approximately 300 parts per million) 



Figure 3. Series vs. Parallel Resonance 
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However, there are several ranges of frequencies where 
the reactance is positive; these are the fundamental (de- 
sired frequency of operation), and the third and fifth 
mechanical overtones (approximately 3 and 5 times the 
fundamental frequency). Since the desired frequency range 
in this application is always the fundamental, the overtones 
must be suppressed. This is done by reducing the loop 
gain at these frequencies. Usually, the amplifier's gain roll 
off, in combination with the crystal parasitics and load 
capacitors, is sufficient to reduce gain and prevent oscil- 
lation at the overtone frequencies. 

The following parameters are for an equivalent circuit of a 
quartz crystal (Figure 4): 

L - motional inductance (typ 120 mH @ 4 MHz) 

C - motional capacitance (typ .01 pf @ 4 MHz) 

R - motional resistance (typ 36 ohm @ 4 MHz) 

Cs - shunt capacitance resulting from the sum of the 
capacitor formed by the electrodes (with the quartz as a 
dielectric) and the parasitics of the contact wires and 
holder (typ 3 pf @ 4 MHz). 

The series resonant frequency is given by: 

Fs= 1/(2ti xsqrt of LC), 

where Xc and XI are equal. 

Thus, they cancel each other and the crystal is then R 
shunted by Cs with zero phase shift. 

The parallel resonant frequency is given by: 

Fp = 1/[2tc x sqrt of L (C Ct/C+Ct)], 
where: Ct = C L +C s 



Cs 

+ 




La/WWIP — 1|— I 

Quartz Equivalent Circuit 

IDI 

Symbolic Representation 
Figure 4. Quartz Oscillator 



Series vs. Parallel Resonance. There is very little differ- 
ence between series and parallel resonance frequencies 
(Figure 3). A series resonant crystal (operating at zero 
phase shift) is desired for non-inverting amplifiers. A parallel 
resonant crystal (operating at or near 180 degrees of 
phase shift) is desired for inverting amps. Figure 3 shows 
that the difference between these two operating modes is 
small. Actually, all crystals have operating points in both 
serial and parallel modes. A series resonant circuit will 
NOT have load caps C1 and C2. A data sheet for a crystal 
designed for series operation does not have a load cap 
spec. A parallel resonant crystal data sheet specifies a 
load cap value which is the series combination of C1 and 
C2. For this App Note discussion, since all the circuits of 
interest are inverting amplifier based, only the parallel 
mode of operation is considered. 
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OSCILLATOR THEORY OF OPERATION 



Ceramic Resonators 

Ceramic resonators are similar to quartz crystals, but are 
used where frequency stability is less critical and low cost 
is desired. They operate on the same basic principle as 
quartz crystals as they are piezoelectric devices and have 
a similar equivalent circuit. The frequency tolerance is 
wider (0.3 to 3%), but the ceramic costs less than quartz. 



Figure 5 shows reactance vs. frequency and Figure 6 
shows the equivalent circuit. 

Typical values of parameters are L = .092 mH, C = 4.6 pf, 
R = 7 ohms and Cs = 40 pf , all at 8 MHz. Generally, ceramic 
resonators tend to start up faster but have looser frequency 
tolerance than quartz. This means that external circuit 
parameters are more critical with resonators. 
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RTxCB (SCC) 
EXTAL (Z180) 



Probe (in) . 



470 pf 



Frequency 
Generator 
1VP-P/Sine 



Power 
Supply 



n 



Vcc 



Gnd 



I.C. 
Under Test 
(All Unused 
Inputs: 10kQTo Vcc) 



SYNCB (SCC) 
XTAL(Z180) 



22 pf 



Probe 
(out) 



Figure 6. Gain Measurement 



Load Capacitors 

The effects/purposes of the load caps are: 

Cap C2 combined with the amp output resistance pro- 
vides a small phase shift. It also provides some attenuation 
of overtones. 

Cap C1 combined with the crystal resistance provides 
additional phase shift. 

These two phase shifts place the crystal in the parallel 
resonant region of Figure 3. 

Crystal manufacturers specify a load capacitance num- 
ber. This number is the load seen by the crystal which is the 
series combination of C1 and C2, including all parasitics 
(PCB and holder). This load is specified for crystals meant 
to be used in a parallel resonant configuration. The effect 
on startup time; if C1 and C2 increase, startup time 
increases to the point at which the oscillator will not start. 
Hence, for fast and reliable startup, over manufacture of 
large quantities, the load caps should be sized as low as 
possible without resulting in overtone operation. 

Amplifier Characteristics 

The following text discusses open loop gain vs. frequency, 
open loop phase vs. frequency, and internal bias. 



Open Loop Gain vs. Frequency over lot, VCC, Processs 
Split, and Temp. Closed loop gain must be adequate to start 
the oscillator and keep it running at the desired frequency. 
This means that the amplifier open loop gain must be equal 
to one plus the gain required to overcome the losses in the 
feedback path, across the frequency band and up to the 
frequency of operation. This is over full process, lot, V cc , and 
temperature ranges. Therefore, measuring the open loop 
gain is not sufficient; the losses in the feedback path 
(crystal and load caps) must be factored in. 

Open Loop Phase vs. Frequency. Amplif ier phase shift at 
and near the frequency of interest must be 1 80 degrees 
plus some, minus zero. The parallel configuration allows 
for some phase delay in the amplifier. The crystal adjusts 
to this by moving slightly down the reactance curve 
(Figure 3). 

Internal Bias. Internal to the IC, there is a resistor placed 
from output to input of the amplifier. The purpose of this 
feedback is to bias the amplifier in its linear region and to 
provide the startup transition. Typical values are 
1Mto20Mohms. 
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PRACTICE: CIRCUIT ELEMENT AND LAY OUT CONSIDERATIONS 



The discussion now applies prior theory to the practical 
application. 

Amplifier and Feedback Resistor 

The elements of the circuit, internal to the IC, include the 
amplifier, feedback resistor, and output resistance. The 
amplifier is modeled as a transconductance amplifier with 
a gain specified as l 0UT /V jN (amps per volt). 

Transconductance/Gain. The loop gain AB = gm x Z1 , 
where gm is amplifier transconductance (gain) in amps/ 
volt and Z1 is the load seen by the output. AB must be 
greater than unity at and about the frequency of operation 
to sustain oscillation. 



Gain Measurement Circuit. The gain of the amplifier can be 
measured using the circuits of Figures 6 & 7. This may be 
necessary to verify adequate gain at the frequency of 
interest and in determining design margin. 

Gain Requirement vs. Temperature, Frequency and Sup- 
ply Voltage. The gain to start and sustain oscillation 
(Figure 8) must comply with: 

gm > 4n 2 f 2 Rq C IN C 0UT t x M 

where: M is a quartz form factor = (1 + C 0UT /C IN + C 0UT /C 0UT ) 2 

Output Impedance. The output impedance limits power to 
the XTAL and provides small phase shift with load cap C2. 



IC Under Test 





DC Bias 











33Q 

AA/VH 



DC Bias 



v out 



'out = ( V out- V b) /33 ) 



V 



Figure 7. Transconductance (gm) Measurement 



VIN it 



CIN 



Wv— 

^^mplifier 



VOUT 



I OSCIN j ^ . IOSC OUT | 
Quartz ' 



n 



COUT 



Inside chip, feedback resistor biases the amplifier in the high gm region. 



External components typically: CIN = COUT = 30 to 50 pf (add 10 pf pin cap). 



Figure 8. Quartz Oscillator Configuration 

■ 
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Load Capacitors 

In the selection of load caps it is understood that parasitics 
are always included. 

Upper Limits. If the load caps are too large, the oscillator 
will not start because the loop gain is too low at the 
operating frequency. This is due to the impedance of the 
load capacitors. Larger load caps produce a longer startup. 

Lower Limits. If the load caps are too small, either the 
oscillator will not start (due to inadequate phase shift 
around the loop), or it will run at a 3rd, 5th, or 7th overtone 
frequency (due to inadequate suppression of higher 
overtones). 

Capacitor Type and Tolerance. Ceramic caps of ±10% 
tolerance should be adequate for most applications. 

Ceramic vs. Quartz. Manufacturers of ceramic resonators 
generally specify larger load cap values than quartz crys- 
tals. Quartz C is typically 15 to 30 pf and ceramic 
typically 100pf. 

Summary. For reliable and fast startup, capacitors should 
be as small as possible without resulting in overtone 
operation. The selection of these capacitors is critical and 
all of the factors covered in this note should be considered. 

Feedback Element 

The following text describes the specific parameters of a 
typical crystal: 

Drive Level. There is no problem at frequencies greater 
than 1 MHz and V cc = 5V since high frequency AT cut 
crystals are designed for relatively high drive levels 
(5-10 mw max). 

Atypical calculation for the approximate power dissipated 
in a crystal is: 

P = 2R (7t x f x C x V cc ) 2 

Where. R = crystal resistance of 40 ohms, C = C1 + Co = 
20 pf. The calculation gives a power dissipation of 2 mW 
at 16 MHz. 

Series Resistance. Lower series resistance gives better 
performance but costs more. Higher R results in more 
power dissipation and longer startup, but can be compen- 
sated by reduced C1 and C2. This value ranges from 200 
ohms at 1 MHz down to 15 ohms at 20 MHz. 

Frequency. The frequency of oscillation in parallel reso- 
nant circuits is mostly determined by the crystal (99.5%). 



The external components have a negligible effect (0.5%) 
on frequency. The external components (C1 ,C2) and lay- 
out are chosen primarily for good startup and reliability 
reasons. 

Frequency Tolerance (initial temperature and aging). Initial 
tolerance is typically ±.01%. Temperature tolerance is 
typically ± .005% over the temp range (-30 to + 1 00 degrees 
C). Aging tolerance is also given, typically 
±.005%. 

Holder. Typical holder part numbers are HC6, 18, 
25, 33, 44. 

Shunt Capacitance. (Cs) typically <7 pf. 

Mode. Typically the mode (fundamental, 3rd or 5th over- 
tone) is specified as well as the loading configuration 
(series vs. parallel). 

The ceramic resonator equivalent circuit is the same as 
shown in Figure 4. The values differ from those specified in 
the theory section. Note that the ratio of L/C is much lower 
than with quartz crystals. This gives a lower Q which allows 
a faster startup and looser frequency tolerance (typically 
±0.9% over time and temperature) than quartz. 

Layout 

The following text explains trace layout as it affects the 
various stray capacitance parameters (Figure 9). 

Traces and Placement. Traces connecting crystal, caps, 
and the IC oscillator pins should be as short and wide as 
possible (this helps reduce parasitic inductance and re- 
sistance). Therefore, the components (caps and crystal) 
should be placed as close to the oscillator pins of the IC 
as possible. 

Grounding/Guarding. The traces from the oscillator pins of 
the IC should be guarded from all other traces (clock, V cc , 
address/data lines) to reduce crosstalk. This is usually 
accomplished by keeping other traces away from the 
oscillator circuit and by placing a ground ring around the 
traces/components (Figure 9). 



Measurement and Observation 

Connection of a scope to either of the circuit nodes is likely 
to affect operation because the scope adds 3-30 pf of 
capacitance and 1 M-1 0M ohms of resistance to the circuit. 
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PRACTICE: CIRCUIT ELEMENT AND LAY OUT CONSIDERATIONS (continued) 



Indications of an Unreliable Design 

There are two major indicators which are used in working 
designs to determine their reliability over full lot and tem- 
perature variations. They are: 

Start Up Time. If start up time is excessive, or varies widely 
from unit to unit, there is probably a gain problem. C1/C2 
needs to be reduced; the amplifier gain is not adequate at 
frequency, or crystal Rs is too large. 




Clock Generator Circuit 



Signals A B 

/ 

(Parallel Traces 
Must Be Avoided) 

Signal C 



Z80180 



64 



Output Level. The signal at the amplifier output should 
swing from ground to V cc . This indicates there is adequate 
gain in the amplifier. As the oscillator starts up, the signal 
amplitude grows until clipping occurs, at which point, the 
loop gain is effectively reduced to unity and constant 
oscillation is achieved. A signal of less than 2.5 Vp-p is an 
indication that low gain may be a problem. Either C1/C2 
should be made smaller or a low R crystal should 
be used. 



Signal Line 
Layout Should 
Avoid High 
Lighted Areas 




Board Design Example 
(Top View) 

• To prevent induced noice, the crystal and load 
capacitors should be physically located as 
close to the LSI as possible. 

• Signal lines should not run parallel to the clock 
oscillator inputs. In particullar, the clock input 
circuitry and the system clock output (pin 64) 
should be separated as much as possible. 

• V C c power lines should be separated from the 
clock oscillator input circuitry. 

• Resistivity between XTAL or EXTAL and the 
other pin should be greater than 1 Mft 



Figure 9. Circuit Board Design Rules 
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SUMMARY 



Understanding the Theory of Operation of oscillators, 
combined with practical applications, should give design- 
ers enough information to design reliable oscillator cir- 
cuits. Proper selection of crystals and load capacitors, 



along with good layout practices, results in a cost effective, 
trouble free design. Reference the following text for Zilog 
products with on-chip oscillators and their general/ 
specific requirements. 



ZILOG PRODUCT USING ON-CHIP OSCILLATORS 

Zilog products that have on-chip oscillators: 
Z8® Family: All 

Z80®: C01, C11, C13, C15, C50, C90, 180, 181, 280 
Z8000®: 8581 

Communications Products: SCC™, ISCC™, ESCC™ 



ZILOG CHIP PARAMETERS 

The following are some recommendations on values/pa- Z8000 Family (8581 only) 
rameters of components for use with Zilog on-chip oscilla- 
tors. These are only recommendations; no guarantees are General Requirements: 
made by performance of components outside of Zilog ICs. 

Finally, the values/parameters chosen depend on the Crystal cut: AT cut, parallel resonant, fundamental mode, 

application. This App Note is meant as a guideline to Crystal Co: < 7 pf for all frequencies, 

making these decisions. Selection of optimal components Crystal Rs: < 150 ohms for all frequencies, 

is always a function of desired cost/performance tradeoffs. Load capacitance: 10 to 33 pf. 



Note: All load capacitance specs include stray capacitance. 

Z8 Family 

General Requirements: 

Crystal Cut: AT cut, parallel resonant, fundamental mode. 
Crystal Co: < 7 pf for all frequencies. 
Crystal Rs: < 100 ohms for all frequencies. 
Load Capacitance: 10 to 22 pf, 15 pf typical. 

Specific Requirements: 

8604: xtal or ceramic, f = 1 - 8 MHz. 
8600/1 0:f = 8MHz. 
8601/03/1 1/13: f = 12.5 MHz. 
8602: xtal or ceramic, f = 4 MHz. 
8680/81/82/84/91 : f = 8, 12, 16, MHz. 
8671:f = 8MHz. 
8612: f = 12, 16 MHz. 
86C08/E08: f = 8, 12 MHz. 

86C09/19: xtal/resonator, f = 8 MHz, C = 47 pf max. 
86C00/1 0/20/30: f = 8, 12, 16 MHz. 
86C1 1/21/91/40/90: f = 12, 16, 20 MHz. 
86C27/97: f = 4, 8 MHz. 
86C12:f= 12, 16 MHz. 
Super8 (all): f = 1 - 20 MHz. 



Z80 Family 

General Requirements: 

Crystal cut: AT cut, parallel resonant, fundamental mode. 
Crystal Co: < 7 pf for all frequencies. 
Crystal Rs: < 60 ohms for all frequencies. 
Load capacitance: 10 to 22 pf. 

Specific Requirements: 

84C01 : C1 = 22 pf, C2 = 33 pf (typ); f = DC to 10 MHz. 
84C90: DC to 8 MHz. 
84C50: sameas84C01. 

84C1 1/13/15: C1 = C2 = 20 -33 pf; f = 6 -10 MHz 
80180: f = 12, 16, 20 MHz (Fxtal = 2 x sys. clock). 
80280: f = 20 MHz (Fxtal = 2 x Fsysclk). 
80181: TBD. 
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ZILOG CHIP PARAMETERS (Continued) 



Communications Family 

General Requirements: 

Crystal cut: AT cut, parallel resonant, fundamental mode. 
Crystal Co: < 7 pf for all frequencies. 
Crystal Rs: < 150 ohms for all frequencies. 
Load capacitance: 20 to 33 pf. 
Frequency: cannot exceed PCLK. 



Specific Requirements: 

8530/85C30/SCC: f = 1 - 6 MHz (1 MHz SCC), 1-8.5 MHz 
(8 MHz SCC). 

85130/ESCC (16/20 MHz), f = 1 - 16.384 MHz. 
16C35/ISCC:f = 1 -10 MHz. 



REFERENCES MATERIALS AND ACKNOWLEDGEMENTS 

Intel Corp., Application Note AP-1 55, "Oscillators for Micro Zilog, Inc., Steve German; Figures 4 and 8. 
Controllers", order #230659-001 , by Tom Williamson, Dec. 

1986. Zilog, Inc., Application Note, "Design Considerations Us- 

ing Quartz Crystals with Zilog Components" - Oct. 1988. 

Motorola 68HC1 1 Reference Manual. 

Data Sheets; CTS Corp. Knights Div., Crystal Oscillators. 

National Semiconductor Corp., App Notes 326 and 400. 
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Questions And Answers 



ZlLOG SCC 

Z8030/Z8530 

March 1992 Questions and Answers 



This document contains the most commonly asked questions about the Zilog SCC. 
They are divided into five sections: 

D Hardware Considerations 13 Synchronous Mode 

M Interrupts and Polling M Miscellaneous Questions 

■ Asynchronous Mode 



HARDWARE CONSIDERATIONS 

This section includes questions and answers on the hard- 
ware interface, the clocks, the FIFO, special modes (Local 
Loopback, DPLL, Manchester), and internal timing con- 
sideration. 

Hardware (Includes DMA Interface) 

Q. What is the SCC transistor count? 

A Approximately 6000 gates, or 18,000 transistors. 

Q. What is the difference between the Z8030 and 
theZ8530? 

A. The Z8030 and Z8530 are packaged from the same 
die. The multiplexed bus (Z8030) or non-multiplexed 
bus (Z8530) version of the chip is selected at packag- 
ing time by an internal bonding option. 

Q. Can /AS be active only when the Z8030 is being 
accessed and High all other times? 

A. Since the interrupt pending bits (IPs) are updated on 
address strobes, interrupts will not occur unless /AS is 
continuous. 

Q. How do /WR and /CE interact on the Z8530? 

A. /WR and /CE are ANDed to enable a transparent latch. 
Data is latched on the falling edge when both /CE and 
/WR go Low. 

Q. How many register pointers does the Z8530 have? 

A. The SCC has only one register pointer for both chan- 
nels. The SIO (Z844X) has two, one for each channel. 



Q. Do you have to write to the pointer with the Z8530 
to access WR0 or RR0? 

A. No. Both registers are accessed automatically without 
first writing to the pointer. 

Q. Does /CE (/CS) have to be High during an interrupt 
acknowledge cycle? 

A. No. 

Q. Does the SCC support full duplex DMA? 

A. The SCC allows full duplex DMA transfers by using the 
DTR/REQ and W//REQ as two separate DMA control 
lines for transmit request and receive request on each 
channel. 

Q. When using full duplex DMA, how do you program 
W//REQ? 

A. W/REQ should be programmed for receive and 
DTR/REQ pin should be programmed for transmit. 

Q. Can both channels make simultaneous DMA 
requests? 

A. Yes. 

Q. Do you have to reset the SCC in hardware? 

A. No. A software reset is the same as a hardware reset. 
(WR9 CO). It also does not matter whether the Z8030 
is in shift right or shift left mode because the address 
is the same in either. 
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Hardware (Includes DMA Interface) 



Q. Do you need to clear the reset bit in WRO after a 
software reset? 

A. The reset is clocked with PCLK; so it must be active 
during reset. 

Q. How long after a hardware reset should you wait 
before programming the SCC. 

A. FourPCLKs. 



Q. Why does the SCC initialization require that the 
External Status Interrupts be reset twice? 

A. Because of the possibility of noise causing an interrupt 
pending bit (IP) to be set. The second reset guaran- 
tees that the latch is clear. If the latch is closed high 
and the external signal is low, the first reset will open 
the latch at the high-to-low transition causing an inter- 
rupt. 



Clocks 

Q. Does PCLK have to have a 50% duty cycle? 

A. The duty cycle doesn't have to be 50% as long as the 
minimum specification is met. 

Q. Can the SCC PCLK be stretched? 

A. Yes, as long as the pertinent specification is met. 
However, this could cause a problem if PCLK is used 
to generate the bit rate. 

Q. The bit rate generator is driven from what sources? 

A. It may be driven from RTxC pin or PCLK, or from a 
crystal. 

Q. How do you connect a bit rate crystal to the SCC? 

A. A crystal can be connected between RTxC and SYNC 
to supply the clock if the SCC is programmed for WR1 1 
D7-1 . 

Q. What is the crystal specification? 

A. It is a fundamental, parallel resonant crystal. For fur- 
ther details see the "Design Considerations Using 
Quartz Crystal with Zilog's Components" Application 
Note. 

Q. Can RTxC on both channels be driven from the 
same crystal. 

A. No. A separate crystal should be used for each chan- 
nel. The crystal should be connected between alter- 
nate solution may be to use crystal on one channel and 
reflect the clock out of the TRxC output and feed it into 
another channel. 



Q. How do you select a crystal frequency? 

A. Time constant: (Clock Frequency/2 x Bit rate x clock 
factor) - 2 (the SCC Technical Manual assumed a 
clock factor of one in the formula). Two examples are 
given below: 



For PCLK=3.6864 For PCLK = 3.9936 MHz 

Bit Rate TC Error Bit Rate TC Error 



38400 


46 


19200 


102 




19200 


94 


9600 


206 




9600 


190 


7200 


275 


12% 


7200 


254 


4800 


414 




4800 


382 


3600 


553 


.06% 


3600 


510 


2400 


830 




2400 


766 


2000 


996 


.04% 


1200 


1534 


1800 


1107 


.03% 






1200 


1662 








600 


3326 








300 


6654 








150 


13310 








134.5 


14844 


.0007% 






110 


18151 


.0015% 






75 


26622 








50 


39934 
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Q. Why are there different Clock factors? 

A. These clock factors enable the SCC to sample the 
center of the data cell. In the 16x mode, the SCC 
divides the bit cell into 16 counts and samples on 
count 8. Clock factors are generally only used with 
Asynchronous modes. 



Q. How is the error in the receive/transmit clock 
reduced? 

A. The ideal way to reduce this error is by adjusting the 
crystal frequency such that only an integer value of TC 
is yielded when the equation is used. 

Q. What are the maximum transfer rates? 

A. The following table shows the PCLK rates (in bps). 





4 MHz 


6 MHz 


8 MHz 


10 MHz 


16 MHz 


20 MHz 


Asynchronous mode: 














External clock 














6x mode (no BRG) 


250K 


375K 


500K 


635K 


1M 


1.25M 


BRG 














16x mode (TX+0) 


62.5K 


93.75K 


125K 


156.5K 


250K 


312.5K 


Synchronous mode: 














Using external clock 


1M 


1.5M 


2M 


2.5M 


4M 


5M 


Using DPLL, FM encoding 


250K 


375K 


500K 


625K 


1M 


1.25M 


Using DPLL, MRZ/NRZI encoding 


125K 


187.5K 


250K 


312.5K 


500K 


625K 


Using DPLL, FM, BRG 


62.5K 


93.75K 


125K 


156.25K 


250K 


312.5K 


Using DPLL, NRZ/NRZI, BRG 


32.25K 


46.88K 


62.5K 


78.125K 


125K 


156.25K 



Q. Can the maximum transfer rate using an external 
clock be achieved? 

A. Yes, but it is not trivial. In order to achieve the maximum 
rate on transmit, the SCC should have a dedicated 
processor or DMA. For example, at a 1 MHz rate, a 
byte must be loaded into the SCC every 8 
microseconds. To achieve the maximum rate on 



receive, requires that the receive clock and the SCC 
PCLK be synchronized. (RTxC to PCLK setup time at 
maximum rate in the Product Specification.) It is 
probably easier to use a slightly faster PCLK SCC, or 
back off slightly from the maximum rate. 



FIFO 

Q. How do you avoid an overrun in the received FIFO? 

A. The receive buffer must be read before the recently 
received data character on the serial input is shifted 
into the receive data FIFO. This FIFO is three bytes 
deep. Thus, if the buffer is not read, the fifth character 
just arrived causes an overrun condition. There is no 
bit that can be set or reset to disable the buffering. 

Q. What happens when you read an empty FIFO? 

A. You read the last character in the buffer. 



Q. When the FIFO gets locked due to an error condi- 
tion, can it still receive? 

A. The SCC continues to receive until an overrun occurs. 

Q. Assuming that there are characters available in the 
FIFO, what happens to them if the receiver goes 
into the hunt mode? 

A. They will remain in the FIFO until they are either read 
by the CPU or DMA, or until the channel is reset. 
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Zilog ESCC™ Controller 

March 1 992 Questions and Answers 



PRODUCT DESCRIPTION 

Q. Which of the following is the major factor in differ- 
entiating the ESCC from the USC Family? 

(a) The ESCC has less communications channels 
than the USC 

(b) The protocols supported by ESCC and USC are 
different 

(c) The ESCC is limited in operation to less than 
5 Mbps, but the USC Family can operate up to 
10 Mbps 



(d) The USC supports the T1 data rate, not the ESCC 

A. (c) Most ESCC and USC Family members have two 
channels and protocols. Support by the SCC is a 
subset of ESCC. Both ESCC and USC can support 
T1 data rates so (a), (b), (d) are not correct. 



Q. Which of the following is not an improvement from 
the SCC to the ESCC? 

(a) The ESCC has deeper FIFOs 

(b) The ESCC has new SDLC enhancements 

(c) The ESCC has added new READ Registers 

(d) The ESCC has added new WRITE Registers 

A. (c) No new READ register addressing is added in the 
ESCC although we allowed some Write Registers 
to become readable through the existing READ 
Register. 



The ESCC has 4 bytes of Tx FIFO and 8 bytes of Rx 
FIFO, while the SCC has 1 byte for the Tx and 3 bytes 
for the Rx. 

The ESCC has many new SDLC enhancements, such 
as automatic EOM reset, automatic opening flag gen- 
eration, etc. 

The ESCC has added WR7' as a new WRITE Register 
to configure the new options, therefore, (a), (b), (d) are 
all differences between the SCC and ESCC. 
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APPLICATIONS 

Q. Which of the following is a benefit from deeper 
FIFOs offered by the ESCC? 

(a) More CPU bandwidths available for other system 
tasks 

(b) Can support faster data rates on each channel 

(c) Can support more channels for the same CPU 

(d) All of the above 

A. (d) (a), (b) and (c) are consequences of reduction in 
interrupt frequency that allows more horsepower to be 
delivered from the CPU. 

Q. Which of the following CRC polynomials is sup- 
ported in ESCC? 

(a) CRC-16 

(b) CRC-32 

(c) CRC-CCITT 

(d) (a) and (c) 

(e) (b) and (c) 

A. (d) CRC-32 is not supported in ESCC. 

Q. How long does it usually take for the customer to 
migrate from SCC to ESCC in order to take the 
advantage of the FIFO? 

(a) Less than 3 month 

(b) About 6 month 

(c) About a year 

A. (a) Since the ESCC is a drop-in replacement to the 
SCC and using the deeper FIFO only requires 
minimal efforts. 



Q. Which of the following is an applications support 
the tool for ESCC: 

(a) Sealevel Board 

(b) Electronic Programmers Manual 

(c) Application Note "Boost Your System Performance 
Using the Zilog ESCC" 

(d) All of the above 
A. (d) 

Q. Which of the following is a target application for the 
ESCC? 

(a) AppleTalk-LocalTalk Peripherals 

(b) X.25 Packet Switches 

(c) SNA connectivity products 

(d) All of the above 

A. (d) ESCC could support the data rate and protocol 
required in the above applications. 
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Support products 



Z8S18000ZCO 

PRODUCT SPECIFICATION 




SUPPORTED DEVICES 

Z8S180, Z85230 

DESCRIPTION 

The kit contains an assembled circuit board, software and 
documentation to support software and hardware devel- 
opment for the Z8S180 and Z85230 system at 18.432 
MHz. 

The supplied cross assembler and link/loader pack- 
age allows full assembly language programming support. 
A board resident debug monitor program allows execut- 
able code to be down-loaded and subsequently de- 
bugged. 

The board comes with sample code to illustrate the 
use of Zilog's Z8S180 and Z85230 in a variety of commu- 
nication applications. 

SPECIFICATIONS 

Power Requirements 

+5Vdc @ 5A 

Dimensions 

Width: 5.65 in. 
Length: 4.0 in. 

Serial Interface 

RS-232 @ 9600 baud 



KIT CONTENTS 

Z8S180/ESCC Evaluation Board 

CMOS Z8S180 MPU 

18.432 MHz Crystal 

Socketed 64K/(8K) x 8 EPROM 

(Programmed with Debug Monitor and 
Device Driver Demonstration Software) 

Socketed 32K/(8K) x 8 Static RAM 

RS-232C PC Interface 

Z8S180 Expansion Header 

Z85230 Expansion Header 

Reset Switch 

NMI Switch 

Cables 

25-pin RS-232 Cable 

Software (IBM® PC Platform) 

ASM800 Z800 Cross Assembler 
MOBJ Link/Loader 
Resident Debug Monitor and 

Device Drivers Demonstration 

Software Source Code 
Z8S180 Example Software 

(a) In ASM800 Assembly 

(b) In Microtec MCC80 C and 
Microtec ASM80 Assembly 

Note: Zilog is not responsible for support 

and maintenance of the above software. 

Documentation 

Z8S180/ESCC Kit User Guide 
Z80180/Z8S180 Product Specification 
Z80180/Z180 Technical Manual 
Z85230 Product Specification 
Z85230/Z80230 Technical Manual 
ASM800 Z800 Cross Assembler User Guide 
MOBJ Link/Loader User Guide 

ORDERING INFORMATION 

Part No: Z8S18000ZCO 



IBM is a registered trademark of International Business Machines Corp. 
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Z8018100ZCO 

PRODUCT SPECIFICATION 




SUPPORTED DEVICES 

Z80181 

DESCRIPTION 

The kit contains an assembled circuit board, software and 
documentation to support software and hardware devel- 
opment for the Z801 81 device. 

The supplied cross assembler and link/loader package 
allows full assembly language support. A board resident 
debug monitor program allows executable code to be 
down-loaded and subsequently debugged. 

SPECIFICATIONS 

Power Requirements 

+5 Vdc @ .65 A 

Dimensions 

Width: 3.65 in. (9.27 cm) 
Length: 4.20 in. (10.67 cm) 

Serial Interface 

RS-232C @ 9600 bits/sec. 



KIT CONTENTS 

Z180181 Evaluation Board 

CMOSZ80181 MPU 
19.6608 MHz Crystal 
Socketed (32K) /8K x 8 EPROM 

(Programmed with Debug Monitor) 
Socketed (32K) /8K x 8 Static RAM 
RS-232C Interface 
Z80181 MPU Expansion Header 
Z80181 Peripheral Signal 
Expansion Header 
Reset switch 
Nmi switch 

Cables 

25-Pin RS-232 Cable 

Software (IBM® PC Platform) 

Z8®/Z80®/Z8000® Cross Assembler 
MOBJ Link/Loader 

Resident Debug Monitor Source Code 
Z80181 Example Software 

Documentation 

Z80181 Kit User Guide 
Z80181 Product Specification 
Z8030/8530 Technical Manual 
Z80 Cross Assembler User Guide 
MOBJ Link/Loader User Guide 

ORDERING INFORMATION 

Part No: Z8018100ZCO 
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Z8018101ZA6 

PRODUCT SPECIFICATION 



Photograph 
Not Available 
At This Time 



DESCRIPTION 

The kit contains software and documentation to support AppleTalk® 
LocalTalk™Link Access Protocol (LLAP) on Zilog's Z181™ (Z80181) . 

The Z8018101ZA6 LLAP driver requires a software licensing 
agreement. The driver is written in ANSI Microtec C and partly in Z181 
Assembler, all contained in diskettes to be executed using an IBM® PC and 
a Microtec C compiler. The driver is composed of a series of C function 
calls that allows the Z181 (in conjunction with proper LLAP hardware 
interface, e.g., Z801 8101ZC0) to transmit and receive LLAP packets. The 
lower level transmission and reception routines are finely tuned using 
Z181 assembler codes. Interface of Zilog's LLAP driver to AppleTalk®'s 
upper layer is left for the user. 

Two examples using the Z181 LLAP driver are included. "Demo.c" 
tests the RTS and CTS handshake between two Z8018101ZCO boards by 
transmitting data between them. This demo requires two terminals 
interfaced via the RS-232C ports to the Z8018101ZCO boards. 
"Mainecho.c" allows two Z8018101ZCO boards to transmit and receive 
LLAP packets. The user can then observe the transactions with his LLAP 
network analyzer. Although this example application program does not 
execute the higher layers of the AppleTalk stack, its inclusion demonstrates 
that the LLAP packets adhere to LLAP specifications. The example 
application programs also provide the user with models on which to base 
his own application program. Source codes and documentations are 
included in the kit. 

Z80181 LLAP Driver Description 

The kit contains source code and documentation (User Guide, LLAP Driver 
for the Z181 and Design, LLAP Driver for the Z1 81) for the Z181 LocalTalk 
Link Access Protocol Driver. The User Guide, LLAP Driver for the Z80181 
describes the Zilog-provided driver for the Z181 and explains how the 
driver is to be used. The Design, LLAP Driver for the Z181 explains how 
the driver works. 

The kit is intended for users who wish to interface an AppleTalk node 
to a LocalTalk network using the Z181 . Interface to the upper layers of the 
AppleTalk stack varies from user to user and is not addressed in the 
documentation. The documentation does provide a general overview of the 
ways the Z181 LLAP driver is intended to fit in a larger software system. 



In general, the Z181 LLAP Driver implements the LLAP protocol 
described in Inside AppleTalk by Sidhu et.al. In particular, the driver 
performs the following functions: 

M It establishes its own node address by transmitting ENQ frames as 
required. 

□ It responds to a received ENQ frame with an appropriate ACK 
frame. 

□ It responds to a received RTS frame with an appropriate CTS frame. 

m It receives any data frames addressed to the node or to the 

broadcast address and routes them according to given instructions. 

□ It transmits an RTS frame before sending a broadcast data frame. 

El It transmits an RTS frame and waits for a CTS frame in response 
before sending a non-broadcast data frame. It retries as necessary. 

o It handles all of the hardware interactions necessary to send and 
receive frames. 

□ It deals with all of the timeouts and timings required by the LLAP 
protocol. 

180181 LLAP Driver Resource Usage 
And Hardware Requirements 

m Approximately 4.5 Kbytes of program memory [ROM 
or RAM) written partly in Z181 assembler and in ANSI C 
(Microtec). 

Si Approxiamtely 1 28 bytes of data memory (RAM). 

□ TxD and RxD of the Z1 81 's SCC are connected to the 
RS-422 differential drivers. 

B The /REQ pin from the Z181's SCC is connected to the 
Z181 DMA's /DREQ1. 

El A 3.6864 MHz crystal is attached to the RTxC and SYNC pins for 
LLAP clocking. 

M The Z181 uses a 10.0 MHz clock 

m Memory access requires no added wait states. 

KIT CONTENTS 

Software 

Z181 LLAP Driver Source Code Diskette 
(licensing agreement required) 

Documentation 

User Guide, LLAP Driver for the Z181 
Design, LLAP Driver for the Z181 

ORDERING INFORMATION 

Part Ho: Z8018101ZA6 
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Z8018101ZCO 

PRODUCT SPECIFICATION 



<£2iLOE 




DESCRIPTION 

The kit contains assembled circuit boards support hard- 
ware, and documentation to support AppleTalk®'s 
LocalTalk™ Link Access Protocol (LLAP) on Zilog's Z181™ 
(Z80181). 

The purpose of the Z181 LLAP Evaluation Board is to 
demonstrate one possible hardware configuration when 
implementing LLAP on the Z181 (Z8018101ZA6)and to 
provide a platform from which to execute example LLAP 
application programs. A diagnostic program (demo.c) is 
included with the kit. This program tests the RTS and CTS 
hand shake between two Z8018101ZCO boards by 
transmitting data between them. This demo requires two 
terminals interfaced via the RS-232C ports to the 
Z801 8001 ZCO boards. 

A second example LLAP application program 
(mainecho.c) allows the board to transmit and receive 
LLAP packets to another board. The user can then 
observe the transactions with his LLAP network analyzer. 
Although the example application program does not 
execute the higher layers of the AppleTalk stack, its 
inclusion in the kit does demonstrate that the LLAP 
packets adhere to LLAP specifications. The example 
application program also provides the user with a model 
on which to base the user's own application program. 

Power Requirements 

+5 Vdc @ 0.50A 

Dimensions 

Width: 4.4 in. 
Length: 5.8 in. 

Serial Interfaces 

RS-232C 

RS-422 LocalTalk DIN-8 and DB-9 interface 



Z80181 LLAP Driver Resource Usage 
And Hardware Requirements 

B Approximately 4.5 Kbytes of program memory 
(ROM or RAM) written partly in Z181 assembler and 
in ANSI C (Microtec). 

m Approxiamtely 128 bytes of data memory (RAM). 

H TxD and RxD of the Z1 81 's SCC are connected to 
the RS-422 differential drivers. 

H The /REQ pin from the Z1 81 's SCC is connected to 
the Z181 DMA's /DREQ1. 

m A 3.6864 MHz crystal is attached to the RTxC and 
SYNC pins for LLAP clocking. 

m The Z181 uses a 10.0 MHz clock 

■ Memory access requires no added wait states. 

KIT CONTENTS 

Two Z8018101ZCO LLAP Evaluation Boards, each has: 

- CMOSZ181 MPU@ 10MHz 

- 20 MHz Crystal (for MPU) 

- 3.6864 MHz Crystal (for LLAP) 

- Socketed 32K x 8 EPROM (containing demo.c) 

- Socketed 32K x 8 Static RAM 

- RS-232C Interface 

- RS-422 Interface for LocalTalk DIN-8 
or DB-9 connection 

- Z181 MPU Expansion Header 

- Z181 Peripheral Expansion Header 

- Reset switch 

- NMI switch 

Hardware 

Two unsocketed 32K X 8 EPROMs containing mainecho.c 
Two LocalTalk DB-9 connection modules 
Two power supply cables 
Two DB-25 connectors 

Documentation 

User Guide, LLAP Driver for the Z181 
Design, LLAP Driver for the Z181 
Z181 Product Specification 
Z85C30 Product Specification 

ORDERING INFORMATION 

Part No: Z8018101ZCO 
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Z8523000ZCO 

PRODUCT SPECIFICATION 




SUPPORTED DEVICES 

Z8S30, Z85C30, Z85230 

DESCRIPTION 

The kit contains an assembled PC/XT/AT circuit board 
with one high speed serial port, selectively driven by RS- 
232C or RS-422 line drivers. The kit also contains soft- 
ware and documentation to support software and hard- 
ware development for Zilog's ESCC™ device. 

The board illustrates the use of Zilog's ESCC in a 
variety of communication applications such as SDLC/ 
HDLC, and high speed ASYNC. 

SPECIFICATIONS 

Power Requirements 

+5 Vdc @ .5 A 

Dimensions 

Width: 4 in. (10.16 cm) 
Length: 5 in. (12.70 cm) 

Serial Interface 

A DB25 port selectively driven by RS-232C or RS-422 at 
selectable baud rates. 



KIT CONTENTS 

Z85230 Evaluation Board 

CMOS Z85230 ESCC 

RS-232C and RS-422 line drivers 

DB25 connector 

Software (IBM® PC Platform) 

Source and executable codes to run the ESCC in SDLC/ 
HDLC and ASYNC modes using DMA, Interrupt and 
polling methods. All codes are written in C and compiled 
using the Microsoft® Quick C compiler. 

Bocumentation 

Z85230 Product Specifications 
Z85230 Technical Manuals 
Z8523000ZCO User Guide 
Sealevel™ User's Manual 

ORDERING INFORMATION 

Part No: Z8523000ZCO 
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Z8018600ZCO 

PRODUCT SPECIFICATION 




SUPPORTED DEVICES 

Z8X30, Z85230, Z85233, Z16C32, 
Z8XC30,Z16C33,Z16C30 

DESCRIPTION 

The kit contains an assembled circuit board, software, 
and documentation to support the evaluation and devel- 
opment of code for Zilog's Z85C30 SCC, Z85230 ESCC™, 
Z85233 EMSCC™, Z16C30 (JSC™, Z16C32 IUSC™, 
Z16C33 MUSC™, and the Z16C35 ISCC™. The purpose of 
the board is to illustrate how the datacom family interfaces 
and communicates with the 80186 CPU. This will help 
potential customers evaluate Zilog's data com-munication 
controllers in an Intel® environment. A board-resident 
monitor program allows code to be downloaded and 
executed. 

SPECIFICATIONS 

Power Requirements 

+5 Vdc @ .50A 

Dimensions 

Width: 8.4 in. (21 .34 cm) 
Length: 9.3 in. (23.62 cm) 



KIT CONTENTS 

Z8018600ZC0 Evaluation Board 

Intel 801 86 Integrated 1 6-bit MPU @ 16 MHz 

CMOS Z85230 ESCC 

CMOSZ16C30 USC 

CMOS Z16C32 IUSC 

CMOSZ16C35 ISCC 

2 (64K) 8Kx8 EPROMs 

6 (256K) 32Kx8 SRAMs 

RS-232C, RS-422, and Apple® LocalTalk™ line drivers 
DB9, DB25, and DIN 8 Interfaces 

Cables 

1 25-pin RS-232C Cable 
14 Jumper Wires 

Software (IBM® PC Platform) 

Resident Monitor for download and 

execution (80186 Assembler source code) 
PC-board terminal emulator 
Z85230, Z16C30/33, Z16C32, and 

Z16C35 Examples Software (All codes 

written in "C" and compiled using 

the Microtec® C compiler.) 

Documentation 

Z85230 ESCC Product Specification 

and Technical Manual 
Z16C30/33 (M)USC Product Specification 

and Technical Manual 
Z1 6C32 IUSC Product Specification 

and Technical Manual 
Z16C35 ISCC Product Specification 

and Technical Manual 
Datacom Evaluation Board Application Note 

ORDERING INFORMATION 

Part No: Z8018600ZCO 



Serial Interfaces 

RS-232C, RS-422 



ZEPMDC00001 

PRODUCT SPECIFICATION 




SUPPORTED DEVICES 

Z16C30, Z16C32, Z16C33 

DESCRIPTION 

The EPM™ Electronic Programmer's Manual provides on- 
line documentation on Zilog's USC™ Universal Serial 
Communicatons Controller (Z16C30), MUSC™ Mono- 
Universal Serial Controller (Z16C33), and the IUSC™ 
Integrated Universal Serial Controller (Z16C32) register 
sets and device operation. Its code generation features 
make it a most valuable tool for the programmer. The 
EPM helps you set the registers to ensure that the device 
operates with your specified settings. Once you have 
selected the field values as a series of C function calls, or 
as an assembler table, you can include this output in any 
software that utilizes the device. 

SPECIFICATIONS 

Minimum Hardware Requirements 

IBM PC/AT with available 51 2K RAM 
5.25 inch, high density, or 3.5 inch, 
high density floppy disk drive 
Hard disk drive 
Color monitor 



KIT CONTENTS 

Software (IBM® PC Platform) 

2 EPM Floppy Diskettes: 5.25 inch, 
high density and 3.5 inch, high density 

Documentation 

EPM User's Guide 
USC/MUSC Technical Manual 
IUSC Technical Manual 
EPM Registration Reply Card 

ORDERING INFORMATION 

Part No: zepmdcooooi 



Minimum Operating System 

MS-DOS, version 3.0 or later 
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ZEPMDC00002 

PRODUCT SPECIFICATION 




SUPPORTED DEVICES 

Z8X30, Z8XC30, Z8X230, Z16C35 

DESCRIPTION 

The EPM™ Electronic Programmer's Manual provides on- 
line documentation on Zilog's Serial Communicatons 
Controller family of devices (Z08X30 NMOS SCC, Z8XC30 
CMOS SCC, Z8X230 ESCC, Z16C35 ISCC™ controller): 
register set and operation of the device. Its code genera- 
tion features make it a most valuable tool for the program- 
mer. The EPM Manual helps you set the registers to 
ensure that the device operates with your specified 
settings. Once you have selected values for the registers, 
the EPM Manual lets you save the field values as a series 
of C function calls or as an assembler table. You can 
include this output in any software that utilizes the device. 

SPECIFICATIONS 

Minimum Hardware Requirements 

IBM® PC/AT with available 51 2K RAM 
5.25 inch, high density, or 3.5 inch, 
high density floppy disk drive 
Hard disk drive 
Color monitor 

Minimum Operating System 

MS-DOS, version 3.0 or later 



KIT CONTENTS 

Software (IBM® PC Platform) 

2 EPM Floppy Diskette: 5.25 inch, 
high density and 3.5 inch, high density 

Documentation 

EPM User's Guide 
SCC Technical Manual 
ESCC Technical Manual 
ISCC Technical Manual 
EPM Registration Reply Card 

ORDERING INFORMATION 

Part No: ZEPMDC00002 
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CMOS ZICTZILOG 
I/O CONTROLLER 



GENERAL DESCRIPTION 



FEATURES 



Zilog's Z80181 I/O Controller (ZICT) is 
a CMOS 8-bit microprocessor con- 
taining the Z180 compatible MPU 
(Z181 MPU), one channel of Z85C30 Serial 
Communication Controller (SCC), Z84C30 
(CTC), two 8-bit general purpose parallel 
ports, and two chip select signals into a 
single 100-pin QFP (Quad Flat Pack) 
package. This high-end superinte-grated 
intelligent peripheral controller is targeted 
for a broad range of intelligent communica- 
tion control applications, i.e., terminals, 
printers, modems, slave communication 
processors for 8-, 16- and 32- bit MPU 
based systems. The Z181 is also ideal for 
enhancement/cost reductions of existing 
hardware using Z80/Z180 with Z8530/ 
Z85C30 applications. 



H Z80180 Compatible MPU Core with 
One Channel ofZ85C30 SCC, Z80 
CTC, Two 8-Bit General-Purpose 
Parallel Ports, and Two Chip Select 
Signals. 

m High Speed Operation (10/12.5 MHz) 

■ Low Power Consumption in Two 
Operating Modes: 
(TBD) mA Typ. (Run Mode) 
(TBD)mATyp. (STOP Mode) 

m Voltage Range 5V±10% 

H TTL/CMOS Compatible 

m Clock Generator 

m Z84C30CTC 



□ One Channel of Z85C30 Serial 
Communication Controller (SCC) 

m- Z180 Compatible MPU Core, which 
has: 

- Enhanced Z80 CPU Core 

- Memory Management Unit (MMU) 
Enables Access to 1MB of 
Memory 

- Two Asynchronous Channels 

- Two DMA Channels 

- Two 16-Bit Timers 

- Clocked Serial I/O Port 

m Two 8-Bit General-Purpose Parallel 
Ports 

M Memory Configurable RAM and ROM 
Chip Select Pins 

m 100-Pin QFP Package 



D7-D0 - 
Control - 
A19-A0- 



/ROMCS 
/RAMCS 



Z80180 
Compatible 
Core 



Glue 
Logic 



A19-A12 



Address 
Decode 
Logic 



SCC 
(1 Channel) 



CTC 



PIA1 



PIA2 



Tx Data 
RxData 



T^r- 6 *- Modem/Control 
8 Signals 



/ Bit Programmable 
8 Bi-directional I/O 
or I/O Pins of CTC 



* O 



Bit Programmable 
Bi-directional I/O 



Z80181 = Z180 + SCC/2 + CTC + PIA 
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ZILOG INTELLIGENT 
PERIPHERAL (ZIP™) 



Z80182 



GENERAL DESCRIPTION 

The Z80182 is the Zilog Intelligent Peripheral 
controller chip that can be used for modems, 
faxes, voice messaging and other communica- 
tions applications. It uses the static Z80180 micropro- 
cessor (Z8S180 MPU core) linked with two channels of 
the industry standard Z85230 ESCC (Enhanced Serial 
Communications Controller), 24 bits of Parallel I/O, and 
a 16550 MIMIC for direct connection to the IBM PC, XT, 
AT, bus. Two different modes of operation allow 
complete flexibility for both internal PC and external 
applications. Also current PC modem software 
compatibility can be maintained with the Z80182's 
ability to MIMIC the 16550 UART chip. The Z80180 acts 
as an interface between the ESCC and 16550 MIMIC 
interface when used in internal applications and between 
the two ESCC channels in the external applications. This 
interface allows for data compression and error 
correction on outgoing and incoming data. 



FEATURES 

a Z8S180 MPU (Static Version of 
Z180T) 

- Code Compatible with 
Zilog Z8CP CPU 

- Additional Instructions 

- Operating Frequency DC to 
16 MHz and 20 MHz 

- Two DMA Channels 

- On-Chip Wait State Generators 

- Two UART Channels 

- Two 16-Bit Timer Counters 

- On-Chip Interrupt Controller 

- On-Chip Clock Oscillator 

- Generator with Idle and Standby 
Modes of Operation 

- Clocked Serial I/O Port 



Two ESCCT Channels 

Three 8-Bit Parallel I/O Ports 

16550 Compatible MIMIC Interface 
for Direct Connection to PC, XT, A T, 
PS2 PC and MicroChannel Bus 

Package 100-Pin QFP (Quad Flat 
Package) or 100-Pin VQFP (Very 
Small Quad Flat Package) 

A Fully Static Device 



D7-D0 
Control 
A19-A0 



Bus 
Transceiver 



TxData • 



Rx Data 



ESCC. 
Control " 
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Channel 
A 



/ROMCS 
/RAMCS 
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Z8S180 
(Static Z801 80) 
MPU Core 



Address 
Decode 



8-Bit Parallel 
PortC 



ESCC Ch.A 
or PortC 



Z1 80 Signals - 
or Port B 



EV1 
EV2 



/TRxCB 



ESCC 
Channel 
B 



8-Bit Parallel 
PortB 



16550 
MIMIC 
Interface 



8-Bit Parallel 
Port A 



MUX 




MUX 




MUX 



16550 MIMIC 
• orESCCCh.B 
and Port A 
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ZILOG DOMESTIC SALES OFFICES INTERNATIONAL SALES OFFICES 

AND TECHNICAL CENTERS 

CALIFORNIA CANADA 

Agoura 818-707-2160 Toronto 416-673-0634 

Campbell 408-370-8120 

Irvine 714-453-9701 GERMANY 

Munich 49-8967-2045 

COLORADO Sommerda 49-3634-23906 

Boulder 303-494-2905 

JAPAN 

FLORIDA Tokyo 81-3-3587-0528 

Largo 813-585-2533 

HONG KONG 

G EO RG I A Kowloon 852-7238979 

Norcross 404-448-9370 

KOREA 

ILLINOIS Seoul 82-2-552-5401 

Schaumburg 708-517-8080 

SINGAPORE 

MINNESOTA Singapore 65-2357155 

Minneapolis 612-944-0737 

TAIWAN 

NEW HAMPSHIRE Taipei 886-2-741-3125 

Nashua 603-888-8590 

UNITED KINGDOM 

OHIO Maidenhead 44-628-392-00 

Independence 216-447-1480 

OREGON 

Portland 503-274-6250 

PENNSYLVANIA 

Ambler 215-653-0230 

TEXAS 

Dallas 214-987-9987 

WASHINGTON 

Seattle 206-523-3591 
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